51.线程池大小

作者 : admin 本文共348个字,预计阅读时间需要1分钟 发布时间: 2024-06-9 共3人阅读

问题

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

本站无任何商业行为
个人在线分享 » 51.线程池大小
E-->