TimerTask實現了Runnable接口,待執行的任務置於run()中。Timer是一個安排TimerTask的類此此兩者一般一起工作。所應用時首先硬創建一個TimerTask的對象,然後用一個Timer的類對象安排執行它
Timer類包含的方法有:
1.Timer()
以常規方式運行task
2.Timer(boolean)
true時使用後臺進程線程。只要剩下的程序記敘運行,後臺進程線程就會執行。
3.public void cancel()
終止Timer的功能執行,但不會對正在執行的任務有影響。當執行cancel方法後將不能再用其分配任務。
4.public void schedule(TimerTask task,Date time)
task被安排在time指定的時間執行,如果時間爲過去時則任務立刻執行。
5.public void schedule(TimerTask task, Date firstTime, long period)
task被安排在time指定的時間執行,執行後將每隔period(毫秒)反覆執行。由於規定的時間間隔並不能保證與時鐘精準的同不步,所以該方
法最適合從短期看保持頻率準確是更重要的的地方
6.public void schedule(TimerTask task, long delay)
task被安排在delay(毫秒)指定的時間後執行。
7.public void schedule(TimerTask task,long delay, long period)
task被安排在delay(毫秒)指定的時間後執行。執行後將每隔period(毫秒)反覆執行。
8.public void scheduleAtFixedRate(TimerTask task,Date firstTime, long period)
task被安排在firstTime指定的時間執行。執行後將每隔period(毫秒)反覆執行。每一次重複的時間時盒第一次執行而不是和前一次執行有關
。因此執行的總速度是固定的。
9.public void scheduleAtFixedRate(TimerTask task,long delay,long period)
task被安排在delay(毫秒)指定的時間後執行。執行後將每隔period(毫秒)反覆執行。每一次重複的時間時盒第一次執行而不是和前一次執
行有關。因此執行的總速度是固定的。
TimerTask的主要方法:
1.public boolean cancel()
終止任務的執行運行。如果Timer時要求循環執行的,則如果正在執行,則執行完了就再步會循環。如果還未執行或處於停歇期,則不會執行
了
2.public abstract void run()
3.public long scheduledExecutionTime()
返回被安排最後執行任務的時間。一般確定任務的當今的實行是否足夠及時 ,證明進行被計劃的活動爲正當:
public void run() {
if (System.currentTimeMillis() - scheduledExecutionTime() >=
MAX_TARDINESS)
return; // Too late; skip this execution.
// Perform the task
}
4.protected TimerTask()
例:
import java.util.*;
import java.io.*;
public class doTask extends TimerTask {
String index;
Timer myTimer = new Timer();
public doTask(String index) {
this.index = index;
}
public void run() {
System.out.println(index);
}
public static void main(String args[]) {
doTask myTask1 = new doTask("First task");
myTask1.start(0,3);
doTask myTask2 = new doTask("Second task");
myTask2.start(0,1);
try{
Thread.sleep(6000);
}
catch(InterruptedException e){
}
myTask1.end();
myTask2.end();//程序結束時用cancel()結束Timer
}
public void start(int delay, int internal) {
myTimer.schedule(this, delay * 1000, internal * 1000); //利用timer.schedule方法
}
public void end(){
myTimer.cancel();
}
}
輸出:
First task
Second task
Second task
Second task
First task
Second task
Second task
Second task