基础—io密集型计算和cpu密集型计算

1、io密集型计算主要是网络,磁盘读写,数据库,web应用等操作,io密集型计算时cpu使用率不高。

 

2、cpu密集型计算主要是数学数字计算,例如:计算圆周率,判断素数,视频解码等,cpu密集型计算会耗费大量cpu资源。

线程池是一种多线程处理形式,它能够在多核处理器上运行多个线程,提高资源利用率。合理的线程池配置可以有效提高应用程序处理任务的效率,对于CPU密集型任务和IO密集型任务,通常有不同的配置策略。 CPU密集型任务通常涉及到计算量大、计算密集的操作,例如图形处理、数值计算等。这类任务主要消耗CPU资源,对CPU的利用率接近100%。对于CPU密集型任务,线程池的配置应当尽量减少上下文切换的开销,并且充分发挥CPU的处理能力。通常,CPU密集型任务的线程池大小可以配置为CPU核心数加一,这样可以利用多核优势,又不至于因为过多的线程导致频繁的上下文切换。 IO密集型任务则通常涉及到大量等待IO操作完成的情况,例如网络请求、文件读写等。这类任务的特点是CPU使用率并不高,但有大量的等待时间。为了提高效率,线程池的大小应该配置得更大,以便在等待IO操作时,CPU可以处理其他任务。IO密集型任务的线程池大小可以是CPU核心数的两倍左右,这样可以保持较高的CPU利用率,同时减少因等待IO操作而导致的线程空闲时间。 具体到线程池参数的配置,可以采用以下方法: 对于CPU密集型任务,可以配置一个固定大小的线程池,大小为`CPU核心数 + 1`: ```java int corePoolSize = Runtime.getRuntime().availableProcessors() + 1; ThreadPoolExecutor executor = new ThreadPoolExecutor(corePoolSize, corePoolSize, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<>()); ``` 对于IO密集型任务,可以配置一个更大的固定大小或可变大小的线程池,大小可以设置为`CPU核心数 * 2`: ```java int corePoolSize = Runtime.getRuntime().availableProcessors() * 2; ThreadPoolExecutor executor = new ThreadPoolExecutor(corePoolSize, corePoolSize, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<>()); ``` 在实际应用中,线程池的配置还需要考虑具体的应用场景和需求,以及系统的资源状况,可能需要经过多次调整和测试才能得到最优配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

拼命_小李

给点鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值