您的位置:首页 > 其它

Timer类 和 TimerTask类。一种有用计时器工具。可以每隔相同时间去执行某任务一次。

2014-02-10 21:21 363 查看

1,编写一个类 继承TimerTask类

public class MyTimerTask extends TimerTask {

@Override
public void run() {
System.out.println("现在是:"+new Date().toString()+" 执行一次任务ing.....");
}

}

2,通过Timer类调用第一步的类 开始任务

public static void main(String[] args) throws Exception {

Timer timer = new Timer();
MyTimerTask myTimerTask = new MyTimerTask();
System.out.println("开始 执行任务");
//从0毫秒开始 每隔1000毫秒 执行myTimerTask中的任务一次
timer.schedule(myTimerTask, 0, 1000);
Thread.sleep(10000);
//10秒后取消任务
timer.cancel();
System.out.println("取消任务");
}


打印结果:

开始 执行任务

现在是:Mon Feb 10 21:17:41 CST 2014 执行一次任务ing.....

现在是:Mon Feb 10 21:17:42 CST 2014 执行一次任务ing.....

现在是:Mon Feb 10 21:17:43 CST 2014 执行一次任务ing.....

现在是:Mon Feb 10 21:17:44 CST 2014 执行一次任务ing.....

现在是:Mon Feb 10 21:17:45 CST 2014 执行一次任务ing.....

现在是:Mon Feb 10 21:17:46 CST 2014 执行一次任务ing.....

现在是:Mon Feb 10 21:17:47 CST 2014 执行一次任务ing.....

现在是:Mon Feb 10 21:17:48 CST 2014 执行一次任务ing.....

现在是:Mon Feb 10 21:17:49 CST 2014 执行一次任务ing.....

现在是:Mon Feb 10 21:17:50 CST 2014 执行一次任务ing.....

取消任务

现在是:Mon Feb 10 21:17:51 CST 2014 执行一次任务ing.....

“取消任务”没有在最后显示 是因为这是两个线程(主线程 和 timer线程) 在最后打印这两行信息几乎是在同一时间,cup执行权随机切换的结果。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐