项目中用到了 Timer 每隔一段时间进行一些操作,现在发现有时候莫名其妙地挂在这个计时器上的操作都不做了,用“JConsole”查看其中的线程以后,发现这个定时器线程也不在了(定时器创建的时候带了名字 Timer timer = new Timer("MyTimer"),所以直接能看到),由于日志太多,之前的日志已经找不到了,所以没有办法看是否是有异常发生以及发生在哪里。初步估计,是不是由于 TimerTask 中有异常抛出,如果定时器中没有处理的话,可能就会出问题。所以看了一下 java.util.Timer 的代码:
-
// 在 TimerThread 中执行任务
-
Timer.java:101:TimerThread
-
// TimerThread 的入口
-
// 这里只有一个 try/finally,如果 mainloop 中有异常抛出的话,肯定就结束运行。
-
Timer.java:503:TimerThread.run()
-
// 主循环体,其中只抓住了 InterruptedException 异常,其他的仍然往外抛。
Recent comments
3 weeks 3 days ago
8 weeks 1 day ago
15 weeks 3 days ago
16 weeks 22 hours ago
37 weeks 1 day ago
1 year 16 weeks ago
1 year 31 weeks ago
1 year 40 weeks ago
1 year 40 weeks ago
1 year 45 weeks ago