对于不同任务的线程池设计方案

本文探讨了线程池的设计方案,包括ThreadPoolExecutor的参数解析、任务提交、关闭策略以及不同任务如何选用线程池。重点分析了CPU密集型、IO密集型任务的处理,线程池的核心参数如corePoolSize、maximumPoolSize和阻塞队列的选择,以及拒绝策略的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

池化技术的应用很广泛,比如线程池、连接池等。在业务有需要的地方建池,将宝贵的资源重复利用,从而提升效率和性能。ThreadPoolExecutor是JAVA提供的一种线程池技术,通过使用它,我们可以很方便的建立

池化技术的应用很广泛,比如线程池、连接池等。在业务有需要的地方建池,将宝贵的资源重复利用,从而提升效率和性能。ThreadPoolExecutor是JAVA提供的一种线程池技术,通过使用它,我们可以很方便的建立线程池。

线程池处理模式

线程池类结构

定时任务

ScheduledExecutorService中有三个方法用来进行不同类型的定时任务处理:

  • schedule : 在给定的延迟时间(delay)后执行任务
  • scheduleAtFixedRate : 在给定的延迟时间后执行任务。并从开始执行任务时算起,经过间隔时间后再次循环的执行此任务
  • scheduleWithFixedDelay : 在给定的延迟时间后执行任务。并从执行完毕任务时算起,经过间隔时间后再次循环的执行此任务

任务提交

我们可以使用execute提交的任务,但是execute方法没有返回值,所以无法判断任务知否被线程池执行成功。通过以下代码可知execute方法输入的任务是一个Runnable类的实例。

我们也可以使用submit方法来提交任务,它会返回一个future,那么我们可以通过这个future来判断任务是否执行成功

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值