JAVA线程池使用注意事项

线程池中重要的配置

  • corePoolSize : 核心线程数量
  • workQueue : 等待队列
  • maximumPoolSize : 最大线程数量

提交任务时,判断的顺序为 corePoolSize --> workQueue -->maximumPoolSize

当线程数小于核心线程数时,创建核心线程

当线程大于等于核心线程数,且任务队列未满时,将任务放入队列

当线程数大于核心线程数,且任务队列已满时,检查最大线程数是否已满,若未满,创建非核心线程,若满,根据拒绝策略抛出异常拒绝任务。

 

拒绝策略—RejectedExecutionHandler

  • AbortPolicy : 直接抛出异常,这是默认策略
  • CallerRunsPolicy : 用调用者所在线程来执行任务
  • DiscardOldestPolicy : 丢弃阻塞队列中最靠前的任务,并执行当前任务
  • DiscardPolicy : 直接丢弃任务

 

遇到的坑!!!

  • 任务提交后长时间没有执行

   1.任务进入了队列,线程还在执行之前的任务。提交的任务还在排队等待执行中

  • 线程执行任务中无故消失

          1.  线程拒绝策略配置为CallerRunsPolicy、DiscardOldestPolicy、DiscardPolicy时 ,线程池满了不会抛出异常。建议将拒绝策略配置为AbortPolicy

          2.  一般情况下,代码只会去捕捉Exception,如果抛出Error(比如内存溢出)则会导致线程退出,而异常信息又没有拿到。最佳的解决办法是给线程池设置UncaughtExceptionHandler

 

 

 

参考地址

Java线程池使用的注意事项 https://www.jianshu.com/p/340f23001a65

 

转载于:https://www.cnblogs.com/kiko2014551511/p/11558091.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java线程池是一种用于管理和复用线程的机制,它可以提高多线程应用程序的性能和效率。线程池中的线程可以被重复使用,避免了频繁创建和销毁线程的开销。 在Java中,可以使用java.util.concurrent包中的Executor框架来创建和管理线程池线程池的大小可以根据应用程序的需求进行调整,以平衡线程的数量和系统资源的利用率。 要进行Java线程池的调优,可以考虑以下几个方面: 1. 线程池的大小:线程池的大小应该根据应用程序的负载和系统资源进行调整。如果线程池的大小过小,可能会导致任务排队等待执行;如果线程池的大小过大,可能会导致系统资源的浪费。可以通过监控线程池的活动线程数和任务队列的长度来确定合适的线程池大小。 2. 任务队列的选择:线程池中的任务队列可以选择不同的实现,如ArrayBlockingQueue、LinkedBlockingQueue、SynchronousQueue等。不同的任务队列有不同的特点,可以根据任务的特性和应用程序的需求选择合适的队列类型。 3. 线程池的拒绝策略:当线程池无法接受新的任务时,可以通过设置拒绝策略来处理。可以选择抛出异常、丢弃任务、丢弃最旧的任务或者调用者自己处理被拒绝的任务。 4. 线程池的生命周期管理:线程池的生命周期包括初始化、运行和关闭三个阶段。在使用线程池后,应该及时关闭线程池,释放资源。 5. 监控和调优:可以通过监控线程池的活动线程数、任务队列的长度、任务执行时间等指标来进行调优。可以使用Java自带的监控工具,如JConsole、VisualVM等,或者使用第三方的监控工具。 以上是Java线程池调优的一些常见方法和注意事项。根据具体的应用场景和需求,可能还需要进行其他的调优措施。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值