美文网首页
list平均分配给多个线程算法

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

作者: 陈明明_ce | 来源:发表于2019-06-17 20:38 被阅读0次

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();

}

}

});

}

相关文章

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

    int num = 20; ExecutorService service = Executors.newFixe...

  • Celery笔记

    Celery 预取机制 Celery 默认启动预取机制,即如果有多个worker,会平均分配给多个worker,如...

  • Mysql数据库优化-分区

    四种分区算法 hash key list range 依据业务逻辑分区:range,list 平均分配:ha...

  • 架构师之路

    手写算法 leetcode 掌握java基础类库 多线程,集合list, map https,tcp,udp mi...

  • 并发编程之美读书笔记 1

    线程的概念 线程不能独立存在,资源由操作系统分配给进程,但是CPU资源是分配给线程的.同一个进程内的线程: 共享:...

  • Python将一个list拆分为多个list

    今天在用python写一个简单的算法时,遇到了list分组的问题,即将一个比较长的list拆分为多个子list,从...

  • ConcurrentModificationException问

    结论:此问题:出现此问题说明多个线程同时操作一个Linkedlist,或单线程下使用list的remove等方法且...

  • 《Java编程思想》中关于线程的描述

    最开始,线程只是用于分配单个处理器的处理时间的一种工具。但假如操作系统本身支持多个处理器,那么每个线程都可分配给一...

  • java知识点

    JAVA的基础知识:数据结构(Map / List / Set等)、设计模式、算法、线程相关、IO/NIO、序列化...

  • R 多线程

    多线程就是将任务切片分配给多个核心处理。举个不恰当的例子,apply函数,就可以将矩阵、数据框按照行(列)等切片,...

网友评论

      本文标题:list平均分配给多个线程算法

      本文链接:https://www.haomeiwen.com/subject/rwslfctx.html