java實(shí)現(xiàn)把一個(gè)List集合拆分成多個(gè)的操作
有些時(shí)候我們需要對(duì)一批數(shù)據(jù)進(jìn)行分批處理, 使用subList方法可以實(shí)現(xiàn)對(duì)List集合進(jìn)行固定長(zhǎng)度的分割.
/*
* List分割
*/
public static List<List<String>> groupList(List<String> list) {
List<List<String>> listGroup = new ArrayList<List<String>>();
int listSize = list.size();
//子集合的長(zhǎng)度
int toIndex = 2;
for (int i = 0; i < list.size(); i += 2) {
if (i + 2 > listSize) {
toIndex = listSize - i;
}
List<String> newList = list.subList(i, i + toIndex);
listGroup.add(newList);
}
return listGroup;
}
public static void main(String[] args) {
List<String> list = new ArrayList<>();
list.add("1");
list.add("2");
list.add("3");
list.add("4");
list.add("5");
list.add("6");
list.add("7");
List<List<String>> lists = groupList(list);
System.out.println("list:" + list.toString());
System.out.println(lists);
}
輸出結(jié)果:

補(bǔ)充知識(shí):java將大集合按照固定長(zhǎng)度拆分為小集合
我們?cè)谑褂胘ava中的集合(Collection、List、Set等)的時(shí)候,可能因?yàn)槟撤N限制需要將大集合按照固定的長(zhǎng)度拆分為N個(gè)小的集合。
如:有一個(gè)List<String> list 里面有1099個(gè)原始,我需要按照固定長(zhǎng)度50,來拆分這個(gè)集合為很多小集合,每個(gè)集合的原始是50個(gè)元素,可能最后一個(gè)小集合的長(zhǎng)度不到50.
如何做呢?網(wǎng)上有不少資料,代碼如下:
/**
* 拆分集合
*
* @param <T> 泛型對(duì)象
* @param resList 需要拆分的集合
* @param subListLength 每個(gè)子集合的元素個(gè)數(shù)
* @return 返回拆分后的各個(gè)集合組成的列表
* 代碼里面用到了guava和common的結(jié)合工具類
**/
public static <T> List<List<T>> split(List<T> resList, int subListLength) {
if (CollectionUtils.isEmpty(resList) || subListLength <= 0) {
return Lists.newArrayList();
}
List<List<T>> ret = Lists.newArrayList();
int size = resList.size();
if (size <= subListLength) {
// 數(shù)據(jù)量不足 subListLength 指定的大小
ret.add(resList);
} else {
int pre = size / subListLength;
int last = size % subListLength;
// 前面pre個(gè)集合,每個(gè)大小都是 subListLength 個(gè)元素
for (int i = 0; i < pre; i++) {
List<T> itemList = Lists.newArrayList();
for (int j = 0; j < subListLength; j++) {
itemList.add(resList.get(i * subListLength + j));
}
ret.add(itemList);
}
// last的進(jìn)行處理
if (last > 0) {
List<T> itemList = Lists.newArrayList();
for (int i = 0; i < last; i++) {
itemList.add(resList.get(pre * subListLength + i));
}
ret.add(itemList);
}
}
return ret;
}
// 運(yùn)行代碼
public static void main(String[] args) {
List<String> list = Lists.newArrayList();
int size = 1099;
for (int i = 0; i < size; i++) {
list.add("hello-" + i);
}
List<List<String>> temps = split(list, 6);
int j = 0;
for (List<String> obj : temps) {
System.out.println(String.format("row:%s -> size:%s,data:%s", ++j, obj.size(), obj));
}
}
其實(shí)我平日用的更多的是guava框架,它自帶了一個(gè)方法可以實(shí)現(xiàn)上面的集合切割的功能。代碼如下:
public static void main(String[] args) {
List<String> list = Lists.newArrayList();
int size = 1099;
for (int i = 0; i < size; i++) {
list.add("hello-" + i);
}
// 切割大集合到指定的長(zhǎng)度:11
List<List<String>> rsList = Lists.partition(list, 11);
int i = 0;
for (List<String> obj : rsList) {
System.out.println(String.format("row:%s -> size:%s,data:%s", ++i, obj.size(), obj));
}
}
推薦大家使用guava的功能,它們都是經(jīng)過嚴(yán)格的單元測(cè)試的代碼。
以上這篇java實(shí)現(xiàn)把一個(gè)List集合拆分成多個(gè)的操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot 配置文件加載位置與優(yōu)先級(jí)問題詳解
這篇文章主要介紹了SpringBoot 配置文件加載位置與優(yōu)先級(jí)問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
Spring?MVC實(shí)現(xiàn)GET請(qǐng)求接收Date類型參數(shù)
這篇文章主要介紹了Spring?MVC實(shí)現(xiàn)GET請(qǐng)求接收Date類型參數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
Spring Boot中的WebSocketMessageBrokerConfigurer接口使用
在SpringBoot中,我們可以使用 WebSocketMessageBrokerConfigurer接口來配置WebSocket消息代理,以實(shí)現(xiàn)實(shí)時(shí)通信,具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-11
詳解Java Proxy動(dòng)態(tài)代理機(jī)制
今天給大家?guī)淼氖顷P(guān)于Java的相關(guān)知識(shí),文章圍繞著Java動(dòng)態(tài)代理機(jī)制展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06
java數(shù)據(jù)結(jié)構(gòu)基礎(chǔ):單鏈表與雙向鏈表
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)單鏈表、雙向鏈表的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
Java工作環(huán)境的配置與Eclipse的安裝過程
這篇文章主要介紹了Java工作環(huán)境的配置與Eclipse的安裝過程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02
Java數(shù)據(jù)結(jié)構(gòu)中堆的向下和向上調(diào)整解析
堆是一顆完全二叉樹,在這棵樹中,所有父節(jié)點(diǎn)都滿足大于等于其子節(jié)點(diǎn)的堆叫大根堆,所有父節(jié)點(diǎn)都滿足小于等于其子節(jié)點(diǎn)的堆叫小根堆。堆雖然是一顆樹,但是通常存放在一個(gè)數(shù)組中,父節(jié)點(diǎn)和孩子節(jié)點(diǎn)的父子關(guān)系通過數(shù)組下標(biāo)來確定2021-11-11
使用Java實(shí)現(xiàn)6種常見負(fù)載均衡算法
Java負(fù)載均衡算法也是分布式系統(tǒng)中的重要組成部分,用于將來自客戶端的請(qǐng)求分配到不同的后端服務(wù)器上,本文將介紹常見的Java負(fù)載均衡算法,輪詢法、加權(quán)隨機(jī)法……一次性讓你了解?6?種常見負(fù)載均衡算法2023-06-06

