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

相关推荐

  1. 51.线大小

    2024-06-07 23:04:04       28 阅读
  2. 52.Fork & Join线

    2024-06-07 23:04:04       33 阅读
  3. C-线

    2024-06-07 23:04:04       39 阅读
  4. 线

    2024-06-07 23:04:04       36 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-07 23:04:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-07 23:04:04       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-07 23:04:04       82 阅读
  4. Python语言-面向对象

    2024-06-07 23:04:04       91 阅读

热门阅读

  1. Switch刷机:安装Android系统和Linux系统

    2024-06-07 23:04:04       131 阅读
  2. 【微信小程序】处理蓝牙数据相关函数

    2024-06-07 23:04:04       31 阅读
  3. 聊聊App在安卓设备中所使用的内存

    2024-06-07 23:04:04       32 阅读
  4. 【考研数学】李艳芳900比李林880难吗 更值得做吗

    2024-06-07 23:04:04       25 阅读
  5. 【debian】常用指令

    2024-06-07 23:04:04       32 阅读
  6. 2024全国高考作文题解读(Chat GPT 4.0版本)

    2024-06-07 23:04:04       26 阅读
  7. 使用Python的xml.etree.ElementTree模块解析XML文件

    2024-06-07 23:04:04       30 阅读