0
点赞
收藏
分享

微信扫一扫

多线程分段执行集合

流计算Alink 2023-02-20 阅读 63


这个是切分集合的

public static <T> List<List<T>> averageAssign(List<T> source, int n) {


List<List<T>> result = new ArrayList<List<T>>();
int remaider = source.size() % n; //(先计算出余数)
int number = source.size() / n; //然后是商
int offset = 0;//偏移量
for (int i = 0; i < n; i++) {
List<T> value = null;
if (remaider > 0) {
value = source.subList(i * number + offset, (i + 1) * number + offset + 1);
remaider--;
offset++;
} else {
value = source.subList(i * number + offset, (i + 1) * number + offset);
}
result.add(value);
}

return result;
}

如果集合小于切分数量,那么结果是这样的,切分后的集合中有空的

[0]
[1]
[2]
[3]
[4]
[]
[]
[]
[]
[]


举报

相关推荐

0 条评论