Java多线程之如何确定线程数的方法

2022-07-16,,,

关于多线程线程数的确定,最近研读过几篇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多线程之如何确定线程数的方法的文章就介绍到这了,更多相关java 确定线程数内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

《Java多线程之如何确定线程数的方法.doc》

下载本文的Word格式文档,以方便收藏与打印。