java线程池大小设定

线程池究竟设置多大要看你的线程池执行的什么任务,

1.CPU密集型

2.IO密集型

3.混合型

任务类型不同,设置的方式也不一样

1、CPU密集型

尽量使用较小的线程池,一般Cpu核心数+1

因为CPU密集型任务CPU的使用率很高,若开过多的线程,只能增加线程上下文的切换次数,带来额外的开销

2、IO密集型

可以使用较大的线程池,一般CPU核心数 * 2

IO密集型CPU使用率不高,可以让CPU等待IO的时候处理别的任务,充分利用cpu时间

3、混合型

可以将任务分为CPU密集型和IO密集型,然后分别使用不同的线程池去处理,按情况而定

线程等待时间所占比例越高,需要越多线程。线程CPU时间所占比例越高,需要越少线程。

最佳线程数目 = (线程等待时间与线程CPU时间之比 + 1)* CPU数目*UCPU(目标CPU计划使用率0<UCPU<=1)

获取CPU数目的java代码 通过RunTime类获取

下面举个例子:
比如平均每个线程CPU运行时间为0.5s,

而线程等待时间(非CPU运行时间,比如IO)为1.5s,

CPU核心数为8,

计划cpu使用率为0.8

那么根据上面这个公式估算得到:int tNums=((0.5+1.5)/0.5)*8*0.8=25。//int自动取整

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值