/**
* 普通thread
* 這是最多見的,建立一個thread,而後讓它在while循環裏一直運行着,
* 經過sleep方法來達到定時任務的效果。這樣能夠快速簡單的實現,代碼以下:
* @author GT
*
*/
public class Task1 {
public static void main(String[] args) {
// run in a second
final long timeInterval = 1000;
Runnable runnable = new Runnable() {
public void run() {
while (true) {
// ------- code for task to run
System.out.println("Hello !!");
// ------- ends here
try {
Thread.sleep(timeInterval);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
};
Thread thread = new Thread(runnable);
thread.start();
}
}
java
import java.util.Timer;
import java.util.TimerTask;安全
/**
*
* 於第一種方式相比,優點 1>當啓動和去取消任務時能夠控制 2>第一次執行任務時能夠指定你想要的delay時間
*
* 在實現時,Timer類能夠調度任務,TimerTask則是經過在run()方法裏實現具體任務。 Timer實例能夠調度多任務,它是線程安全的。
* 當Timer的構造器被調用時,它建立了一個線程,這個線程能夠用來調度任務。 下面是代碼:
*
* @author GT
*
*/
public class Task2 {
public static void main(String[] args) {
TimerTask task = new TimerTask() {
@Override
public void run() {
// task to run goes here
System.out.println("Hello !!!");
}
};
Timer timer = new Timer();
long delay = 0;
long intevalPeriod = 1 * 1000;
// schedules the task to be run in an interval
timer.scheduleAtFixedRate(task, delay, intevalPeriod);
} // end of main
}併發
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;ide
/**
*
*
* ScheduledExecutorService是從Java SE5的java.util.concurrent裏,作爲併發工具類被引進的,這是最理想的定時任務實現方式。
* 相比於上兩個方法,它有如下好處:
* 1>相比於Timer的單線程,它是經過線程池的方式來執行任務的
* 2>能夠很靈活的去設定第一次執行任務delay時間
* 3>提供了良好的約定,以便設定執行的時間間隔
*
* 下面是實現代碼,咱們經過ScheduledExecutorService#scheduleAtFixedRate展現這個例子,經過代碼裏參數的控制,首次執行加了delay時間。
*
*
* @author GT
*
*/
public class Task3 {
public static void main(String[] args) {
Runnable runnable = new Runnable() {
public void run() {
// task to run goes here
System.out.println("Hello !!");
}
};
ScheduledExecutorService service = Executors
.newSingleThreadScheduledExecutor();
// 第二個參數爲首次執行的延時時間,第三個參數爲定時執行的間隔時間
service.scheduleAtFixedRate(runnable, 10, 1, TimeUnit.SECONDS);
}
}工具