这篇文章将为大家详细讲解有关JAVA工具如何将一个list均分成n个list,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
分批处理一块大数据: 例如,从(Excel ,txt ,数据库 )中一行一行的读数据,最终读了1W+数据,然后对这1W+数据又要进行业务处理,一条一条的遍历太慢了。可以把这个大的list拆成n个,然后用n个线程去跑,这样效率就会快很多。下述代码就是其中用到关于的一个工具类: 把一个List均分成n个小的list
入参:一个大的list
出参:n个小的list
思路:像小学做除法一样。 10/3=3余1. 10条数据,分成3个list,那每个list分3个还多1个,那只有前面的都多分1个,第一个list分3个然后加1个余数等于4个。第2个list分3个,然后最后一个list分3个。代码如下,可以直接拷贝运行
/**
* 将一个list均分成n个list
* @param source
* @return
*/
public static <T> List <List<T>> averageAssign(List<T>source,intn){
List <List<T>> result=new ArrayList<List<T>>();
int remainder=source.size()%n; //先计算出余数
int number=source.size()/n; //然后是商
int offset=0;//偏移量(用以标识加的余数)
for(int i=0;i<n;i++){
List<T>value;
if(remainder>0){
value=source.subList(i*number+offset, (i+1)*number+offset+1);
remainder--;
offset++;
}else{
value=source.subList(i*number+offset, (i+1)*number+offset);
}
result.add(value);
}
return result;
}
关于JAVA工具如何将一个list均分成n个list就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。