CPU 密集型 && IO 密集型

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密集型程序才合适,而且中间可能没有线程的上下文切换(一个核心处理一个线程)

IO密集型

  • 此时,系统大部分的状况是CPU在等I/O (硬盘/内存) 的读/写操作,但CPU的使用率不高。简单的说,就是需要大量的输入输出,比如读写文件、DB读写、传输文件、网络请求。

区别和使用:

  • IO密集型:大量网络,文件操作
  • CPU 密集型:大量计算,cpu 占用越接近 100%, 耗费多个核或多台机器

你可能感兴趣的:(java,jvm,开发语言)