package com.lc.concurrent;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
public class MyThreadPoolExecutor {
//最大可用的CPU核数
public static final int PROCESSORS=Runtime.getRuntime().availableProcessors();
//线程最大的空闲存活时间,单位为秒
public static final int KEEPALIVETIME=60;
//任务缓存队列长度
public static final int BLOCKINGQUEUE_LENGTH=500;
public ThreadPoolExecutor createThreadPool(){
return new ThreadPoolExecutor(PROCESSORS * 2,PROCESSORS * 4,KEEPALIVETIME,TimeUnit.SECONDS,
new ArrayBlockingQueue<Runnable>(BLOCKINGQUEUE_LENGTH));
}
}
一般来说池中总线程数是核心池线程数量两倍,只要确保当核心池有线程停止时,核心池外能有线程进入核心池即可。
我们所需要关心的主要是核心池线程的数量该如何设置。线程中的任务最终是交给CPU的线程去处理的,而CPU可同时
处理线程数量大部分是CPU核数的两倍,运行环境中CPU的核数我们可以通过Runtime.getRuntime().availableProcessors()
这个方法而获取。理论上来说核心池线程数量应该为Runtime.getRuntime().availableProcessors()*2,那么结果是否
符合我们的预期呢,可以来测试一下。
package com.lc.concurrent;
import java.util.Arrays;
import java.util.Random;
import java.util.concurrent.ThreadPoolExecutor;
public class CreateThreads {
public synchronized static void main(String[] args) {
System.out.println(MyThreadPoolExecutor.PROCESSORS);
new CreateThreads().test();
}
public synchronized void test(){
ThreadPoolExecutor threadPoolExecutor=new MyThreadPoolExecutor().createThreadPool();
for (int i = 0; i <= 100; i++) {
MyTask myTask = new MyTask(i);
threadPoolExecutor.execute(myTask);
}
threadPoolExecutor.shutdown();
}
}
class MyTask implements Runnable{
private int i;
public MyTask(int i){
this.i=i;
}
@Override
public void run() {
System.out.println("任务"+i+"开始执行"+System.currentTimeMillis());
for (int i=0;i<32766;i++){
Random random=new Random();
int randNum=random.nextInt();
int[] a={1,2,3,4,5,6,9,18,290,238,991,100,19,1932,randNum};
Arrays.sort(a);
Arrays.hashCode(a);
Arrays.stream(a);
}
System.out.println("任务"+i+"结束执行"+System.currentTimeMillis());
}
}
本机CPU核数为4,可同时处理8线程,测试结果如下:
核心池线程数量 执行耗时(毫秒,多次测试结果以/间隔)
4 474/479/471
8 430/436/421
12 432/425/438
16 437/431/449
20 471/481/469
可以发现当线程数量小于CPU核数两倍时速度明显较慢,超过两倍后速度差不多,当核心池数量过多时,速度又会显著下降
由此可以看出,核心池线程数量大小应在CPU核数两倍以上且不过多。
所以说,将线程池的核心池线程数量配置为CPU核数的两倍是比较合适的。
分类: java多线程与并发编程
http://www.dluky.com/maaaLZFXC8gj5kTRf4.html
http://www.dluky.com/mwwwoWQY1KYXdHBK7X.html
http://www.dluky.com/mbbsik1L2UQf01i2Lc.html
http://www.dluky.com/mfggqr1MB8oFFrcFWK4.html
http://www.dluky.com/mhoth9XcC8n3gTBBeW.html
http://www.dluky.com/mtuozDYbF78dNqdLZ8F.html
http://www.dluky.com/mdfroBP0fXQFViPdb.html
http://www.dluky.com/mjklVG4FgbQHJeCmMr.html
http://www.dluky.com/mwddWMb1X34KQli81G.html
http://www.dluky.com/mcvxTXFCUVZSPjYrK9.html
http://www.dluky.com/myhjro2PAQbHqJYDBg.html
http://www.dluky.com/mfgjhP2jC2bMZA2jAgS.html
http://www.dluky.com/mfht6OlQ0QbJDDnoDR.html
http://www.dluky.com/maxdEeeQlg1VWpaWHp.html
http://www.dluky.com/mloqLqO8OTeI9NCZX1.html
http://www.dluky.com/mlwgOSCD69Ij0DUITN.html
http://www.dluky.com/mqghIjY2TG4h1Glq5J.html
http://www.dluky.com/mrfhCUU5IDIlBP1WOf.html
http://www.dluky.com/mfjqO8kmIcTWpGLUhR.html
http://www.dluky.com/mnqh9cRKDB2QU01D5N.html
http://www.dluky.com/mxrhhiO64NUUQiaPlP.html
http://www.dluky.com/mmwyhSVQQBXJpORWK7.html
http://www.dluky.com/mkkw6hKYGbUIBXl97F.html
http://www.dluky.com/mvty07LRpTVkZ6eNPW.html
http://www.dluky.com/mzujCjNeoL4Iil7pUN.html
http://www.dluky.com/mhhki7fUbIUR8fE5e9.html
http://www.dluky.com/mhjfgLfLLa3MmanhXfN.html
http://www.dluky.com/mwwwqN5f95oEJRmLUp.html
http://www.dluky.com/mbbsBC2ZmjHJ42NSTM.html
http://www.dluky.com/mfggqebfFkI299NJPSC.html
http://www.dluky.com/mhotn09nBBMH0fdOXL.html
http://www.hbzjk.net/saaaDZINi3lLA7BrGe.html
http://www.hbzjk.net/sbbsQ6PMFDhHfhOn6H.html
http://www.hbzjk.net/sjkl27k6grXi6kd27B.html
http://www.hbzjk.net/shotcUdmDg5SjBQXRP.html
http://www.hbzjk.net/saerFdPMNq2RY8j49i.html
http://www.hbzjk.net/sdfncog7ZImaohjJj.html
http://www.hbzjk.net/sjklYKYkU7caiiqYPa.html
http://www.hbzjk.net/swddhgGgoUXMgP2nfG.html
http://www.hbzjk.net/scvxVc4316TN4JFMI2.html
http://www.hbzjk.net/syhjLr4TrD0h73C9Om.html
http://www.hbzjk.net/sfgjhP4bjPnW8n3WKLX.html
http://www.hbzjk.net/sfht9J3C2iga41aGbe.html
http://www.hbzjk.net/saxd7SiQk7PECA0cqZ.html
http://www.hbzjk.net/sloqH8K4IAMO4IZRMX.html
http://www.hbzjk.net/slwgCNkJUqeiNSMIKC.html
http://www.hbzjk.net/sqghiAKE0I6KriW3WU.html
http://www.hbzjk.net/srfhCqKLKm7F303qoY.html
http://www.hbzjk.net/sfjq6HpgDmIJ8qWeof.html
http://www.hbzjk.net/snqhCie3NKbidYrIUF.html
http://www.hbzjk.net/sxrhoYN8TU5g9GkXIY.html
http://www.hbzjk.net/smwy0Y4NlT7Y8cbhij.html
http://www.hbzjk.net/skkwQSCULgL3PFB8B0.html
http://www.hbzjk.net/svtyKennVNH60KkYDK.html
http://www.hbzjk.net/szuj7nVrXY4h2bl2CX.html
http://www.hbzjk.net/shhkUYngVlO31b6XST.html
http://www.hbzjk.net/shjfg2Fmn9CmeILIFcg.html
http://www.hbzjk.net/shjfgXlVOXp13XqFVMN.html
http://www.hbzjk.net/skkwNa9ghIkXnQ3H35.html
http://www.hbzjk.net/sbbs4MigWa7hq86NaL.html
http://www.hbzjk.net/sfggqGppaU4QaSd9kqo.html
http://www.hbzjk.net/shotBiYBPq85U4T5H9.html