线程池(ThreadPoolExecutor)重要参数解析

本文详细解析了ThreadPoolExecutor线程池的重要参数,包括corePoolSize、maximumPoolSize、keepAliveTime、allowCoreThreadTimeOut和workQueue等,探讨了不同类型的线程池如newCachedThreadPool、newFixedThreadPool和newSingleThreadExecutor的优缺点。此外,还介绍了线程池的拒绝策略及四种预定义策略,以及线程池的状态和关键方法的执行逻辑。
摘要由CSDN通过智能技术生成

ThreadPoolExecutor线程池继承ExecutorService,用来解决2个问题:

  • 执行大量异步任务的时候,通过每个线程一个任务的方法,减少线程调用开销,提升性能;
  • 设置线程池最大线程数,管理线程资源的调用。执行大量任务的时候会不断消耗线程;

常见的三种线程池:

  • newCachedThreadPool
    • 优点:任何需要的时候都会创建新线程执行任务,当有可用的空闲线程(空闲线程在60秒内如果没有使用,会将该线程终止)时会优先使用可用线程,除非无可用线程;可以运用于执行大量运行时间短的任务;
    • 缺点:不适合运行时间长的任务,因为会占着CPU资源,导致CPU性能降低;有可能会在短时间内创建大量线程执行任务;
  • newFixedThreadPool
    • 优点:corePoolSize和maximumPoolSize相同,只会产生一定数量的线程,如果线程都在使用,会优先将任务放在队列中等待,并不会再产生新的线程。适合执行运行时间较长的任务;
    • 缺点:如果线程池使用率不高,会导致大量空闲的线程,占用CPU资源。产生大量的空闲线程的原因,是因为此种线程池的keepAliveTime设置为0,也就是空闲线程永远不会被终止。反之,如果大量长时间运行任务占用了所有线程,那么其他任务要加入线程池,只能在无边界队列中等待,又会导致占着大量内存。
    • 特点&
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值