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