list平均分配给多个线程算法

int num = 20;

ExecutorService service = Executors.newFixedThreadPool(num);

int rows = 3568;

int pageSize = 100;

int pageSum = (rows - 1) / pageSize + 1;

List<Integer> list = new ArrayList<>();

for (int i = 1; i <= pageSum; i++){

list.add(i);

}

int baseNum = pageSum / num;

int remainderNum = pageSum % num;

int end = 0;

for (int i = 0; i <num; i++)

{

int start = end ;

end = start + baseNum;

if(i == (num-1)){

end = pageSum;

}else if( i < remainderNum){

end = end + 1;

}

int finalEnd = end;

service.submit(

new Runnable() {

@Override

public void run() {

List<Integer> listSmall = list.subList(start, finalEnd  );

try {

for (Integer integer : listSmall)

{

System.out.println(integer);

}

} catch (Exception e) {

e.printStackTrace();

}

}

});

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 一. Java基础部分.................................................
    wy_sure阅读 4,038评论 0 11
  • pyspark.sql模块 模块上下文 Spark SQL和DataFrames的重要类: pyspark.sql...
    mpro阅读 9,941评论 0 13
  • 超高速音视频编码器用法: ffmpeg [options] [[infile options] -i infile...
    吉凶以情迁阅读 4,827评论 0 4
  • 【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔...
    开心的锣鼓阅读 3,404评论 0 9
  • 四 季 ...
    經權相適阅读 313评论 1 3

友情链接更多精彩内容