现在的位置: 首页 > 自动控制 > 工业·编程 > 正文

计算密集型线程和IO密集型线程

2019-05-18 05:35 工业·编程 ⁄ 共 356字 ⁄ 字号 暂无评论

1.计算密集型线程池

cpu使用率较高(也就是一些复杂运算,逻辑处理),所以线程数一般只需要cpu核数的线程就可以了。 这一类型的在开发中多出现的一些业务复杂计算和逻辑处理过程中。

数量一般为 N+1个   N为CPU核心数

2.IO密集型

cpu使用率较低,程序中会存在大量I/O操作占据时间,导致线程空余时间出来,所以通常就需要开cpu核数的两倍的线程, 当线程进行I/O操作cpu空暇时启用其他线程继续使用cpu,提高cpu使用率 通过上述可以总结出:线程的最佳数量: 最佳线程数目 = ((线程等待时间+线程CPU时间)/线程CPU时间 )* CPU数目 线程等待时间所占比例越高,需要越多线程。线程CPU时间所占比例越高,需要越少线程。这一类型在开发中主要出现在一些读写操作频繁的业务逻辑中。

数量一般为:2N + 1个  N为CPU核心数

给我留言

留言无头像?