前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >java销毁定时器_Java 定时器退出解决方案

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

作者头像
全栈程序员站长
发布2022-11-04 16:28:44
1.3K0
发布2022-11-04 16:28:44
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

项目中用到了 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”退出了。跟前面所说的问题一模一样,只不过项目中还有很多别的线程,所以主程序并未退出。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月17日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档