首页 > 编程语言 > 详细

Java多线程之如何确定线程数

时间:2019-06-01 00:24:22      阅读:140      评论:0      收藏:0      [点我收藏+]

     关于多线程的线程数的确定,最近研读过几篇paper,在此做一下笔记,方便使用时翻看。

1、《Java 虚拟机并发编程》中介绍

技术分享图片

技术分享图片

就是说:线程数 =  CPU的核心数 * (1 - 阻塞系数)

 

另一篇:《Java Concurrency in Practice》即《java并发编程实践》,给出的线程池大小的估算公式:

技术分享图片

 

Nthreads=Ncpu*Ucpu*(1+w/c),其中 Ncpu=CPU核心数,Ucpu=cpu使用率,0~1;W/C=等待时间与计算时间的比率

仔细推敲两个公式,其实类似,在cpu使用率达100%时,其实结论是一致的,这时候计算线程数的公式就成了,Nthreads=Ncpu*100%*(1+w/c) =Ncpu*(1+w/c)。

那么在实践应用中计算的公式就出来了,【以下推算,不考虑内存消耗等方面】,如下:

1、针对IO密集型的,阻塞耗时w一般都是计算耗时几倍c,假设阻塞耗时=计算耗时的情况下,Nthreads=Ncpu*(1+1)=2Ncpu,所以这种情况下,建议考虑2倍的CPU核心数做为线程数

2、对于计算密集型的阻塞耗时趋于0,即w/c趋于0,公式Nthreads = Ncpu

总结:

   上面只是做出的较为普适的线程数公式推算,实际应用中可以会考虑多个方面,比如内存容量消耗,任务耗时等,可以对这个公式进行不断的场景调整适配。

 

Java多线程之如何确定线程数

原文:https://www.cnblogs.com/xuzhujack/p/10958006.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!