java线程池最大线程数_Java项目中,线程池中线程数量太大会有什么影响?

1.线程栈是需要分配内存空间的,所以有数量上限

2.cpu切换线程涉及到上下文恢复,这个是需要耗费时间的,如果线程非常多而且切换频繁(处理IO密集任务),这个时间损耗是非常可观的。

线程池应该设置多大,取决于你处理的任务类型。

对于CPU密集型的任务,因为线程中基本不会有阻塞导致让出CPU,只有在时间片用完以后,才可能让出CPU,这种情况发生线程切换的次数要少很多,因此不建议设置太大,netty的建议是设置为2倍的cpu核心数。

为何不设置为核心数呢?因为系统上不仅仅只跑你的java程序,还有别的进程也会来抢占你的cpu资源。因此,你需要在更多的争抢机会和更少的上下文切换之间取得平衡。

另外这里说的IO密集型任务,仅仅是指你的IO很可能是未就绪需要阻塞等待的任务。如果你的IO事件已经就绪,随时可读可写,任何时候都不会对线程产生任何阻塞,那实际就是CPU密集型任务了。

如果你要处理的是会对线程产生阻塞的IO密集型任务,那要提高吞吐量,一般有两种办法

一种是基于IO多路复用+NIO/AIO,这种办法实际是想办法去掉不必要的阻塞,尽量把阻塞型的IO密集任务,转成CPU密集任务,这样你只需要少量线程也可以获得很高的吞吐量。这就是为何select、poll 、epoll、nginx可以用很少的线程可以获得极大吞吐量的原因。

另一种办法就是很简单的扩大线程数了,理论上来说,只要你的线程数,不会导致明显的上下文切换损耗,而且不会造成内存溢出,线程池就可以设置的足够大。某大厂的rpc框架设置的默认最大线程数就超过了500,核心线程数也大大超过了CPU核心数。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值