如何设置核心线程数量

如何设置核心线程数量

CPU密集度高

**特点:**主要消耗CPU资源,需要大量的计算和逻辑处理。不会堵塞, 不会因为IO操作或其他堵塞原因导致暂停线程。

所以核心线程数量CPU核心 + 1

IO型任务

**特点:**任务主要消耗在等待IO操作完成上,可能存在堵塞CPU等待IO操作完成。

所以核心线程数量: 2 * CPU核心 + 1

为什么为2 * CPU核心 + 1

主要从

最大化IO利用率: 在IO操作的时候,CPU可能会空闲等待IO完成,通过增加线程池的核心线程数,让更多的线程同时执行IO操作,从而提高系统的IO利用率。

**减少IO等待时间:**多个线程可以并发执行IO操作,有助于减少每个线程等待IO操作完成的时间,踢啊高

**保证连续任务执行:**线程堵塞的时候让其他线程上去工作。

总结一句话就是提高CPU使用率,让CPU忙起来。

为什么+1?

因为多出来一个线程可用于更加平滑的线程替补,比如有的线程执行完了, 或者休眠中断等,多出来一个线程瞬间出来替补避免CPU空闲。

为什么是2*cpu核心+1

其实3*cpu核心+1也是很好的,但是这个根据具体的物理硬件和业务来选择,但是通过经验和性能测试告诉我们,2* cpu核心+1才是保守的最广泛的,我leader告诉我:开发项目最重要的不是选择什么高端技术也不是像做数学题一样怎么秀怎么来,而是选择最稳定的方案。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哇塞大嘴好帅(DaZuiZui)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值