Timer类中的"Timer already cancelled."

最近有个问题,在没有timer调用cancel()方法的情况下,报以下异常

Exception in thread "main" java.lang.IllegalStateException: Timer already cancelled.

at java.util.Timer.sched(Timer.java:397)

at java.util.Timer.schedule(Timer.java:193)

at TimerTest.main(TimerTest.java:23)

说一个可以排查的点,就是timer在执行任务的过程中如果抛出了RuntimeException,并且接着又去执行另一个新任务时,会认定定时器已经取消,产生这个异常,所以可以在定时任务之间排查是否有异常抛出。



import java.util.Timer;
import java.util.TimerTask;

public class TimerTest {
	private Timer timer = new Timer();
	private void lanuch() {
		TimerTask task = new TimerTask() {
			@Override
			public void run() {
				System.out.println("task start");
				throw new RuntimeException();

			}
		};
		timer.schedule(task, 0, 1000);
	}

	private void addNewTask() {
		timer.schedule(new TimerTask() {
			@Override
			public void run() {
				System.out.println("exception");
			}
		}, 100);
	}
	
	public static void main(String[] args) throws Exception {
		TimerTest test = new TimerTest();
		test.lanuch();
		Thread.sleep(1000);
		test.addNewTask();
	}
}


输出:


task start
Exception in thread "Timer-0" java.lang.RuntimeException
at TimerTest$1.run(TimerTest.java:11)
at java.util.TimerThread.mainLoop(Timer.java:555)
at java.util.TimerThread.run(Timer.java:505)
Exception in thread "main" java.lang.IllegalStateException: Timer already cancelled.
at java.util.Timer.sched(Timer.java:397)
at java.util.Timer.schedule(Timer.java:193)
at TimerTest.addNewTask(TimerTest.java:19)
at TimerTest.main(TimerTest.java:31)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值