您的位置:首页 > 游戏 > 游戏 > 51.线程池大小

51.线程池大小

2024/12/23 15:24:48 来源:https://blog.csdn.net/qq_36352889/article/details/139535842  浏览:    关键词:51.线程池大小

问题

1.线程池太小会导致程序不能充分利用系统资源、容易导致饥饿。

2.线程池过大导致更多的线程上下文切换,占用更多的内存。

情况一:CPU密集型运算

应用程序是做一些数据分析,需要大量的使用cpu,程序代码全部都是跟cpu相关的,线程数量 = cpu的核数 + 1, 能够实现最优的cpu利用率。

情况二:I/O密集型运算

CPU不能总是处于繁忙状态,例如当执行业务计算时,这时候会使用cpu资源。但执行I/O操作时,远程RPC调用时,数据库操作时,cpu就闲下来了。可以利用多线程提高它的利用率。

公式:线程数 = 核数 * 期望CPU利用率  *  总时间(cpu计算时间+等待时间) / cpu计算时间

例如:4核cpu计算时间是50%,其他等待时间是50%,期望cpu被100%利用

           4 * 100% * 100% / 50% = 8

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com