標籤:tst timertask rup 相關 sys adp stack public art
說明:先上代碼,筆記後續補充。
public class ScheduleTest1 {
private static long start;
private static ScheduledExecutorService executorService = Executors.newScheduledThreadPool(2);
/**
* 如果用timer.schedule加上sleep之後的輸出是1001 6005
* 第一個線程的sleep會影響第二個線程
*如果第一個線程掛掉了,則的哥線程不會執行
*timer是和系統時間相關的
*
* 使用executorService不會出現以上的問題
*
* @param args
*/
public static void main(String[] args) {
TimerTask task = new TimerTask() {
@Override
public void run() {
// System.out.println(System.currentTimeMillis()-start);
// try {
// Thread.sleep(5000);
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
throw new RuntimeException();
}
};
TimerTask task1 = new TimerTask() {
@Override
public void run() {
System.out.println(System.currentTimeMillis()-start);
}
};
Timer timer = new Timer();
start = System.currentTimeMillis();
// //1s後執行
// timer.schedule(task,1000);
// //3s後執行
// timer.schedule(task1,3000);
executorService.schedule(task,1000, TimeUnit.MILLISECONDS);
executorService.schedule(task1,3000, TimeUnit.MILLISECONDS);
}
}
JAVA並發編程4