线程池设置大小

线程池的理想大小取决于被提交任务的类型以及所部属系统的特性。在系统中一般不固定线程池的大小,而是通过某种配置机制来提供。或则根据处理器的数量来决定:

我们可以通过如下代码来获取处理器的数量:

//获取处理器的数量 
System.out.println(Runtime.getRuntime().availableProcessors());
 
 
  • 1
  • 2
  • 1
  • 2

这行代码可以直接输出当前机器处理器的数量。

对于线程池的大小不能过大也不能过小。过大就会有大量的线程在相对较少的CPU和内存上竞争,过小会导致许多空闲的处理器无法工作,从而降低吞吐率。

对于设置线程池的大小我们需要考虑的问题有: 
1、机器有多少个CPU? 
2、多大内存? 
3、任务是计算密集型还是IO密集型? 
4、是否需要像JDBC这种稀缺资源? 


NT(最佳线程数量)= N * U * (1+W/C) 
上面:NT:最优线程数量 
N:服务器CPU的数量 
U:CPU的利用率; 
W/C: 是线程等待时间与线程CPU时间之比 
当然上面只是一个估计值,也不是绝对的,具体的还得通过监控服务器的运行状态来确定。但是大致可以推断出一个结论: 
可以得出一个结论:

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


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值