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

时间:2021-09-20 20:33:58

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执行权随机切换的结果。