/** * 普通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(); } }
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; /** * * * 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); } }