开发案例——线程池/任务未抓取异常处理

本文对比了Java中的TimerTask、Executors及Quartz处理异常的不同方式。TimerTask会在遇到未抓取异常时中断后续任务;Executors虽不停止任务但不输出异常信息;Quartz则既能继续执行任务又能通过log4j输出异常信息。建议使用Quartz进行定时任务管理。

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

问题描述:

  1. 使用 java.util.TimerTask 任务中断(遇到未抓取异常时后续任务不执行);

     2.  使用 java.util.concurrent.Executors.xxx 线程池对于未抓取异常无异常输出,无法定位问题;

定位方法:

对比 TimerTask/Executors/Quartz 三者对抛出异常的反应

 

TimerTask

Executors

Quartz

是否中断后续任务

是否有异常输出

是(uncaught)

是(log4j)

 

问题解决:

建议:

  1. 对于定时任务,建议使用 quartz 库。(使用 TimerTask 有未抓取异常时会导致当前Timer终止,后续任务无法执行)
  2. 线程池有未抓取异常时不会导致后续任务中断,但是没有异常信息的输出,难以定位问题,对此,有三种方案:
    1. )自己封装一个RunnableWrapper、CallableWrapper,将传入的任务包裹其中,在run方法中try-catch,并统一对未抓取异常进行异常处理/输出;
    2. )继承ThreadPoolExecutor的方式来创建线程池,重写其afterExecute(Thread, Throwable)方法,判断第二个参数非空时获得其异常信息,统一进行处理;(注意:仅对 executor.execute(..) 启动的任务有效,executor.submit(..)的无效)
    3. )创建线程池时,传入自定义的ThreadFactory,在其创建线程时,使用setUncaughtExceptionHandler(..)设置每个线程的未抓取异常处理句柄,统一进行处理;(注意:仅对 executor.execute(..) 启动的任务有效,executor.submit(..)的无效)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值