java销毁定时器_Java 定时器退出解决方案

项目中用到了 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 异常,其他的仍然往外抛。

Timer.java:518:TimerThread.mainloop()

从上面的代码可以看出,如果执行的任务中有其他任何运行时异常(RuntimeException)抛出,就必然导致定时器取消,也就是说挂在这个定时器上所有的人物都要被取消。明白了其内部处理机制,就要将其应用于实践,看如下例子:

WrongTimerTask.java:

package org.supermmx.example.timer;

import java.util.Timer;

import java.util.TimerTask;

/**

* Wrong timer task.

*

* @author SuperMMX

*/

public class WrongTimerTask extends TimerTask {

private int count = 0;

public void run() {

System.out.println(count);

count ++;

if (count == 3) {

throw new NullPointerException("Test Exception");

}

}

public static void main(String[] args) {

try {

WrongTimerTask task = new WrongTimerTask();

Timer timer = new Timer("TestTimer");

timer.scheduleAtFixedRate(task, 0, 1000);

} catch (Exception e) {

e.printStackTrace();

}

}

}

上述代码中,每隔一秒钟打印一个递增的数值,等于 3 的时候抛一个空指针异常,结果怎么样呢?整个程序全部就退出了,就因为其中唯一的线程“TestTimer”退出了。跟前面所说的问题一模一样,只不过项目中还有很多别的线程,所以主程序并未退出。0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值