IO密集型和计算密集型

一个计算为主的程序(专业一点称为CPU密集型程序)。多线程跑的时候,可以充分利用起所有的cpu核心,比如说4个核心的cpu,开4个线程的时候,可以同时跑4个线程的运算任务,此时是最大效率。

但是如果线程远远超出cpu核心数量 反而会使得任务效率下降,因为频繁的切换线程也是要消耗时间的。

因此对于cpu密集型的任务来说,线程数等于cpu数是最好的了。

如果是一个磁盘或网络为主的程序(IO密集型)。一个线程处在IO等待的时候,另一个线程还可以在CPU里面跑,有时候CPU闲着没事干,所有的线程都在等着IO,这时候他们就是同时的了,而单线程的话此时还是在一个一个等待的。我们都知道IO的速度比起CPU来是慢到令人发指的。所以开多线程,比方说多线程网络传输,多线程往不同的目录写文件,等等。

此时 线程数等于IO任务数是最佳的。
 

### 特点 - **CPU密集型场景**:CPU性能高于磁盘内存,CPU利用率可达100%,I/O操作时间短。大量时间花费在计算操作上,如使用CPU进行神经网络的前向反向计算,涉及大量卷积数值运算。使用过多线程会增加上下文切换开销,导致性能下降 [^1][^3]。 - **IO密集型场景**:主要进行IO操作,执行IO操作时间长,CPU常处于空闲状态,利用率不高 [^2]。 ### 配置 - **CPU密集型场景**:通常使用较小的线程池,选择固定大小的线程池,使线程数等于可用的CPU核心数,或根据实际情况调整。例如使用`Executors.newFixedThreadPool(int nThreads)`创建固定大小线程池,nThreads设置为CPU核心数 [^3][^5]。 - **IO密集型场景**:线程数一般设置为2倍CPU核数。可使用`Executors.newCachedThreadPool()`创建可缓存线程池,适合短期大量的IO密集型任务 [^2][^5]。 ### 应用 - **CPU密集型场景**:适用于需要大量计算的场景,如科学计算、数据挖掘、图像处理等。通过合理配置线程池,充分利用CPU核心,提高计算效率 [^1][^3]。 ```java import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class CPUIntensiveExample { public static void main(String[] args) { int coreCount = Runtime.getRuntime().availableProcessors(); ExecutorService fixedPool = Executors.newFixedThreadPool(coreCount); fixedPool.submit(() -> { // 模拟CPU密集型计算 for (int i = 0; i < 1000000; i++) { Math.pow(i, 2); } System.out.println(Thread.currentThread().getName() + " 执行任务"); }); fixedPool.shutdown(); } } ``` - **IO密集型场景**:常用于网络请求、文件读写等场景。通过增加线程数,在部分线程进行IO操作时,其他线程可继续使用CPU,提高CPU利用率 [^2]。 ```java import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class IOIntensiveExample { public static void main(String[] args) { ExecutorService cachedPool = Executors.newCachedThreadPool(); cachedPool.submit(() -> { try { File file = new File("example.txt"); FileInputStream fis = new FileInputStream(file); byte[] buffer = new byte[1024]; while (fis.read(buffer) != -1) { // 处理数据 } fis.close(); System.out.println(Thread.currentThread().getName() + " 执行任务"); } catch (IOException e) { e.printStackTrace(); } }); cachedPool.shutdown(); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值