欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java拆分List的三種方式總結(jié)

 更新時(shí)間:2023年05月31日 14:13:49   作者:程序員xiaozhang  
開(kāi)發(fā)中我們可能會(huì)遇到一個(gè)大的集合,然后我們需要對(duì)集合進(jìn)行拆分,在這篇文章中,主要介紹了Java拆分List的三種方式,需要的可以參考下

開(kāi)發(fā)中我們可能會(huì)遇到一個(gè)大的集合,然后我們需要對(duì)集合進(jìn)行拆分,然后再對(duì)拆分的集合進(jìn)行相關(guān)的操作。當(dāng)然我們可以自己寫(xiě)一個(gè)拆分的方法,我自己寫(xiě)過(guò)用了不少代碼,但是感覺(jué)還不是很好,最近看了不少工具才發(fā)現(xiàn)很多的大神們其實(shí)已經(jīng)寫(xiě)了工具類(lèi),我們站在大神肩膀上開(kāi)發(fā)就行了。

將List拆分很多的小的List的過(guò)程,我們稱(chēng)之為分片,當(dāng)然也可以稱(chēng)為L(zhǎng)ist的分隔,選一個(gè)你喜歡的名字就行,你喜歡的就是最好的(這怎么像渣男語(yǔ)錄啊,一定要擦亮眼睛,不要讓別人畫(huà)大餅)。

在Java中分片的常見(jiàn)實(shí)現(xiàn)方法有以下幾種:

1:使用Google的Guava框架實(shí)現(xiàn)切片。

2:使用Apache的commons框架實(shí)現(xiàn)切片。

3:使用Hutool工具類(lèi)實(shí)現(xiàn)切片。

接下來(lái)我們就分別看一下,你的項(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é)果,開(kāi)發(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ì)說(shuō),為什么要給出三種的,給出一種切片方法不就可以了,因?yàn)榱信e每一種方法都需要引入對(duì)應(yīng)的jar包,所以自己按需引用,如果你的項(xiàng)目中已經(jīng)引用了對(duì)應(yīng)的jar就參考其中的一個(gè)例子寫(xiě)就行了。

又有小伙伴要問(wèn)這樣切分有什么用途呢?這個(gè)用途還是很廣泛的,比如你做批量新增數(shù)據(jù)的時(shí)候,如果你有幾萬(wàn)條數(shù)據(jù)要新增到數(shù)據(jù)庫(kù),最好對(duì)這幾萬(wàn)條數(shù)據(jù)拆分一下再插入數(shù)據(jù)庫(kù),例如ORACLE你如果一次批量新增超過(guò)1000條就有可能會(huì)新增失敗。Mysql批量新增一次過(guò)多也可能回報(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ò)誤可以通過(guò)設(shè)置如下參數(shù)解決:

SET GLOBAL max_allowed_packet = 1024*1024*64

但是你不能把這個(gè)參數(shù)設(shè)置無(wú)限大,設(shè)置無(wú)限大也是不好的。所以批量新增大量數(shù)據(jù)最好拆分一下。

到此這篇關(guān)于Java拆分List的三種方式總結(jié)的文章就介紹到這了,更多相關(guān)Java拆分List內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論