单机环境的时候,最近碰到了需要将数据进行分割,每个线程来处理不同的数据
话不多说直接上代码
private List<List<KeyWord>> averageAssign(List<KeyWord> source, int n){
List<List<KeyWord>> result = new ArrayList<>();
int remainder = source.size() % n; //余数
int number = source.size() / n; //商
int offset = 0;//
for (int i = 0; i < n; i++) {
List<KeyWord> value = null;
//当余数不为0,循环把余数循环加入到每个组中
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;
}