CPU 密集型
- 计算密集型,此时系统运作大部分的状况是CPU Loading 100%,CPU要读/写I/O(硬盘/内存),I/O在很短的时间就可以完成,而CPU还有许多运算要处理,CPU Loading很高。
- 比如说要计算1+2+3+…+ 1亿、计算圆周率后几十位、数据分析。
都是属于CPU密集型程序。 - 在单核CPU情况下,线程池有6个线程,但是同一时间只能运行一个线程,考虑到线程之间还有上下文切换的时间消耗,其实不如单个线程执行高效。所以,单核CPU处理CPU密集型程序,最好不使用多线程
- 假如是6核CPU,理论上运行速度可以提升6倍。每个线程都有 CPU 来运行,并不会发生等待 CPU 时间片的情况,也没有线程切换的开销
- 所以,多核CPU处理CPU密集型程序才合适,而且中间可能没有线程的上下文切换(一个核心处理一个线程)
- 比如说要计算1+2+3+…+ 1亿、计算圆周率后几十位、数据分析。
IO密集型
- 此时,系统大部分的状况是CPU在等I/O (硬盘/内存) 的读/写操作,但CPU的使用率不高。简单的说,就是需要大量的输入输出,比如读写文件、DB读写、传输文件、网络请求。
区别和使用:
- IO密集型:大量网络,文件操作
- CPU 密集型:大量计算,cpu 占用越接近 100%, 耗费多个核或多台机器