Java拆分List的三種方式總結(jié)
開發(fā)中我們可能會(huì)遇到一個(gè)大的集合,然后我們需要對(duì)集合進(jìn)行拆分,然后再對(duì)拆分的集合進(jìn)行相關(guān)的操作。當(dāng)然我們可以自己寫一個(gè)拆分的方法,我自己寫過用了不少代碼,但是感覺還不是很好,最近看了不少工具才發(fā)現(xiàn)很多的大神們其實(shí)已經(jīng)寫了工具類,我們站在大神肩膀上開發(fā)就行了。
將List拆分很多的小的List的過程,我們稱之為分片,當(dāng)然也可以稱為List的分隔,選一個(gè)你喜歡的名字就行,你喜歡的就是最好的(這怎么像渣男語錄啊,一定要擦亮眼睛,不要讓別人畫大餅)。
在Java中分片的常見實(shí)現(xiàn)方法有以下幾種:
1:使用Google的Guava框架實(shí)現(xiàn)切片。
2:使用Apache的commons框架實(shí)現(xiàn)切片。
3:使用Hutool工具類實(shí)現(xiàn)切片。
接下來我們就分別看一下,你的項(xiàng)目中如果已經(jīng)引用了相應(yīng)的jar包你就可以使用相應(yīng)的方法實(shí)現(xiàn)List切片。
1.Google Guava
先在項(xiàng)目的 pom.xml 中添加框架支持,增加以下配置:
<dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>31.0.1-jre</version> </dependency>
有了 Guava 框架之后,只需要使用 Lists.partition 方法即可實(shí)現(xiàn)分片,如下代碼所示:
List<String> tempList = Arrays.asList("水星","金星","地球","火星", "冥王星","土星","天王星","海王星","冥王星","木星"); // size 是把集合拆分的大小,size 為表示拆分成拆分的集合大小為3, // 后面不足3的有多少算多少 List<List<String>> partition = Lists.partition(tempList, 3); System.out.println(partition);
結(jié)果如下:(拆成如下結(jié)果,開發(fā)的時(shí)候再遍歷集合進(jìn)行應(yīng)用)
[[水星, 金星, 地球],
[火星, 冥王星, 土星],
[天王星, 海王星, 冥王星],
[木星]]
2.apache commons
先在項(xiàng)目的 pom.xml 中添加框架支持,增加以下配置:
<dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-collections4</artifactId> <version>4.4</version> </dependency>
有了 commons 框架之后,只需要使用 ListUtils.partition 方法即可實(shí)現(xiàn)分片,如下代碼所示:
List<String> tempList = Arrays.asList("水星","金星","地球","火星","冥王星","土星","天王星","海王星","冥王星","木星"); List<List<String>> partition = ListUtils.partition(tempList, 6); System.out.println(partition);
輸出結(jié)果如下:
[[水星, 金星, 地球, 火星, 冥王星, 土星],
[天王星, 海王星, 冥王星, 木星]]
3.Hutool
先在項(xiàng)目的 pom.xml 中添加框架支持,增加以下配置:
<dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.7.14</version> </dependency>
有了 Hutool 框架之后,只需要使用 ListUtil.partition 方法即可實(shí)現(xiàn)分片,如下代碼所示:
List<String> tempList = Arrays.asList("水星","金星","地球","火星","冥王星","土星","天王星","海王星","冥王星","木星"); List<List<String>> partition = ListUtil.partition(tempList, 5); System.out.println(partition);
輸出結(jié)果如下:
[[水星, 金星, 地球, 火星, 冥王星],
[土星, 天王星, 海王星, 冥王星, 木星]]
有的小伙伴可能會(huì)說,為什么要給出三種的,給出一種切片方法不就可以了,因?yàn)榱信e每一種方法都需要引入對(duì)應(yīng)的jar包,所以自己按需引用,如果你的項(xiàng)目中已經(jīng)引用了對(duì)應(yīng)的jar就參考其中的一個(gè)例子寫就行了。
又有小伙伴要問這樣切分有什么用途呢?這個(gè)用途還是很廣泛的,比如你做批量新增數(shù)據(jù)的時(shí)候,如果你有幾萬條數(shù)據(jù)要新增到數(shù)據(jù)庫,最好對(duì)這幾萬條數(shù)據(jù)拆分一下再插入數(shù)據(jù)庫,例如ORACLE你如果一次批量新增超過1000條就有可能會(huì)新增失敗。Mysql批量新增一次過多也可能回報(bào)如下
com.mysql.jdbc.PacketTooBigException: Packet for query is too large (16888937 > 1048576).
You can change this value on the server by setting the max_allowed_packet' variable.
這種錯(cuò)誤,當(dāng)然這種錯(cuò)誤可以通過設(shè)置如下參數(shù)解決:
SET GLOBAL max_allowed_packet = 1024*1024*64
但是你不能把這個(gè)參數(shù)設(shè)置無限大,設(shè)置無限大也是不好的。所以批量新增大量數(shù)據(jù)最好拆分一下。
到此這篇關(guān)于Java拆分List的三種方式總結(jié)的文章就介紹到這了,更多相關(guān)Java拆分List內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Maven構(gòu)建時(shí)跳過部分測試的實(shí)例
下面小編就為大家分享一篇Maven構(gòu)建時(shí)跳過部分測試的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助2017-11-11SpringBoot中的ApplicationListener事件監(jiān)聽器使用詳解
這篇文章主要介紹了SpringBoot中的ApplicationListener事件監(jiān)聽器使用詳解,ApplicationListener是應(yīng)用程序的事件監(jiān)聽器,繼承自java.util.EventListener標(biāo)準(zhǔn)接口,采用觀察者設(shè)計(jì)模式,需要的朋友可以參考下2023-11-11Java中的PrintWriter 介紹_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
PrintWriter 是字符類型的打印輸出流,它繼承于Writer。接下來通過本文給大家介紹java中的 PrintWriter 相關(guān)知識(shí),感興趣的朋友一起學(xué)習(xí)吧2017-05-05java序列化對(duì)象根據(jù)不同配置動(dòng)態(tài)改變屬性名的方法
本文主要介紹了java序列化對(duì)象根據(jù)不同配置動(dòng)態(tài)改變屬性名的方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05SpringBoot統(tǒng)一數(shù)據(jù)返回格式的實(shí)現(xiàn)示例
本文主要介紹了SpringBoot統(tǒng)一數(shù)據(jù)返回格式,它提高了代碼的可維護(hù)性和一致性,并改善了客戶端與服務(wù)端之間的通信,具有一定的參考價(jià)值,感興趣的可以了解一下2024-05-05java發(fā)送http get請(qǐng)求的兩種方式
這篇文章主要為大家詳細(xì)介紹了java發(fā)送http get請(qǐng)求的兩種方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05