线程池究竟设置多大要看你的线程池执行的什么任务了,CPU密集型、IO密集型、混合型,任务类型不同,设置的方式也不一样

任务一般分为:CPU密集型、IO密集型、混合型,对于不同类型的任务需要分配不同大小的线程池

1、CPU密集型

尽量使用较小的线程池,一般Cpu核心数+1

因为CPU密集型任务CPU的使用率很高,若开过多的线程,只能增加线程上下文的切换次数,带来额外的开销

2、IO密集型

方法一:可以使用较大的线程池,一般CPU核心数 * 2

IO密集型CPU使用率不高,可以让CPU等待IO的时候处理别的任务,充分利用cpu时间

方法二:线程等待时间所占比例越高,需要越多线程。线程CPU时间所占比例越高,需要越少线程。
下面举个例子:
比如平均每个线程CPU运行时间为0.5s,而线程等待时间(非CPU运行时间,比如IO)为1.5s,CPU核心数为8,那么根据上面这个公式估算得到:((0.5+1.5)/0.5)*8=32。这个公式进一步转化为:
最佳线程数目 = (线程等待时间与线程CPU时间之比 + 1)* CPU数目

3、混合型

可以将任务分为CPU密集型和IO密集型,然后分别使用不同的线程池去处理,按情况而定

      

最新文章

  1. 自己封装的一个JS分享组件
  2. 移动销售端app的需求分析
  3. MyBatis使用总结+整合Spring
  4. C#分割字符串
  5. Jsp与servlet的区别 1
  6. 【读书笔记】iOS-GCD-block-后台运行
  7. CodeForces - 417A(思维题)
  8. 移植 FFMPEG-2.2.4 -(编译)
  9. LeetCode 6. ZigZag Conversion Question
  10. 做ie8css样式时浏览器默认杂项模式遇到的一个小坑
  11. CodeForces 609B The Best Gift
  12. ImageView及其子类(三)
  13. 单元测试(Spring)
  14. PHP如何强制下载文件
  15. 日常报错记录4:ssh工程复制粘贴顺序。
  16. C语言之路-2-判断
  17. composer 安装thinkphp
  18. Hadoop伪分布式模式安装
  19. USE " cc.exports.* = value " INSTEAD OF SET GLOBAL VARIABLE"
  20. 日常英语---十一、MapleStory/Monsters/Level 201-210(Dark Demon Eagle Rider)

热门文章

  1. codeforces625C
  2. MyBatis学习(七)MyBatis关联映射之多对多映射
  3. 2015 HIAST Collegiate Programming Contest H
  4. MT【53】对数平均做数列放缩
  5. 使用metasploit中Evasion模块
  6. 自学Aruba4.3-Aruba AC基础配置(2)
  7. [luogu1829][bzoj2154][国家集训队]Crash的数字表格 / JZPTAB【莫比乌斯反演】
  8. [luogu3978][bzoj4001][TJOI2005]概率论【基尔霍夫矩阵+卡特兰数】
  9. json序列化 & 反序列化
  10. springboot 读取 resource文件