java實(shí)現(xiàn)把一個(gè)List集合拆分成多個(gè)的操作
有些時(shí)候我們需要對一批數(shù)據(jù)進(jìn)行分批處理, 使用subList方法可以實(shí)現(xiàn)對List集合進(jìn)行固定長度的分割.
/* * List分割 */ public static List<List<String>> groupList(List<String> list) { List<List<String>> listGroup = new ArrayList<List<String>>(); int listSize = list.size(); //子集合的長度 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ǔ)充知識:java將大集合按照固定長度拆分為小集合
我們在使用java中的集合(Collection、List、Set等)的時(shí)候,可能因?yàn)槟撤N限制需要將大集合按照固定的長度拆分為N個(gè)小的集合。
如:有一個(gè)List<String> list 里面有1099個(gè)原始,我需要按照固定長度50,來拆分這個(gè)集合為很多小集合,每個(gè)集合的原始是50個(gè)元素,可能最后一個(gè)小集合的長度不到50.
如何做呢?網(wǎng)上有不少資料,代碼如下:
/** * 拆分集合 * * @param <T> 泛型對象 * @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); } // 切割大集合到指定的長度: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)格的單元測試的代碼。
以上這篇java實(shí)現(xiàn)把一個(gè)List集合拆分成多個(gè)的操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot 配置文件加載位置與優(yōu)先級問題詳解
這篇文章主要介紹了SpringBoot 配置文件加載位置與優(yōu)先級問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09Spring?MVC實(shí)現(xiàn)GET請求接收Date類型參數(shù)
這篇文章主要介紹了Spring?MVC實(shí)現(xiàn)GET請求接收Date類型參數(shù),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07Spring 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)知識,文章圍繞著Java動(dòng)態(tài)代理機(jī)制展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06java數(shù)據(jù)結(jié)構(gòu)基礎(chǔ):單鏈表與雙向鏈表
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)單鏈表、雙向鏈表的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08Java工作環(huán)境的配置與Eclipse的安裝過程
這篇文章主要介紹了Java工作環(huán)境的配置與Eclipse的安裝過程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02Java數(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)中的重要組成部分,用于將來自客戶端的請求分配到不同的后端服務(wù)器上,本文將介紹常見的Java負(fù)載均衡算法,輪詢法、加權(quán)隨機(jī)法……一次性讓你了解?6?種常見負(fù)載均衡算法2023-06-06