博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java中List按指定大小分割
阅读量:6408 次
发布时间:2019-06-23

本文共 1556 字,大约阅读时间需要 5 分钟。

之前写过的代码,几个月后遇到类似的功能,感觉很熟悉,稍微费些劲也能做到,但是觉得有些不甘。明明之前整理好的为什么要重新做?百度参考其他人的思路感觉不是很顺心,个人原因吧。于是翻箱倒柜找出以前的代码,贴在这里留作笔记,或许也有其他同行有相似需求,聊做参考。

/** * 数组切分 *  */public class PartitionList {        /**     * 方式一     * 非均分,最后一组数量可能小于其它组数量     * @param list     * @param unitSize     * @return     */    public static 
List
> splitList_1(List
list, int unitSize) { if (list == null || list.isEmpty() || unitSize < 1) return null; int wholeSize = list.size(); int groupNum = wholeSize / unitSize; List
> result = new ArrayList
>(); for (int i = 0; i < groupNum; i++) { List
subList = list.subList(i * unitSize, (i + 1) * unitSize); result.add(subList); } if(unitSize * groupNum < wholeSize){ List
restList = list.subList(unitSize * groupNum, wholeSize); result.add(restList); } return result; } /** * 方式二 * 非均分,最后一组数量可能小于其它组数量 * @param list * @param unitSize * @return */ public static
List
> splitList_2(List
list, int unitSize) { if (list == null || list.isEmpty() || unitSize < 1) return null; int wholeSize = list.size(); List
> result = new ArrayList
>(); int start = 0; int end = 0; while(start < wholeSize){ end = start + unitSize; if(end > wholeSize){ end = wholeSize; } List
subList = list.subList(start, end); result.add(subList); start = start + unitSize; } return result; }}

当然,这里面也是有参考其他大拿思路的地方,自己稍作了些改动。

百度过程中发现有人提到guava,appache ListUtil,java8新特性均可切分List,在这里Mark一下。

转载于:https://www.cnblogs.com/fragranting/p/8572865.html

你可能感兴趣的文章
Oracle的体系结构(七)
查看>>
1.1 Flink Home翻译
查看>>
centos7系统root无法通过su切换到某个普通用户
查看>>
文件传输之ftp
查看>>
2018年最新人工智能书单,总有一本你爱的
查看>>
使用硬盘,安装双系统,Win7+CentOS
查看>>
网络总结
查看>>
C++--面向对象的基本概念
查看>>
String StringBuffer StringBuilder
查看>>
Centos 6.5 部署 LAMP
查看>>
gitlab系列详解
查看>>
来来来,互相伤害。互相关注啊!!
查看>>
JavaBean
查看>>
区块链里的智能合约安全
查看>>
Springmvc+mybatis+shiro+Dubbo+ZooKeeper+Redis+KafK
查看>>
B2G编译前的准备
查看>>
关于host文件位置和作用的介绍
查看>>
linux进程的查看与管理
查看>>
2018北京理工大学区块链技术讲座
查看>>
#!/usr/bin/env node\n
查看>>