public static void main(String[] args) {
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
try {
System.out.println("thread "+Thread.currentThread().getName()+" start to run.");
Thread.sleep(2000);
System.out.println("thread " + Thread.currentThread().getName() + " done.");
} catch (Exception e) {
e.printStackTrace();
}
}
});
System.out.println("main start to run.");
t1.start();
System.out.println("main done.");
}
默認情況下,線程t1它不會立馬結束,執行結果是
我們希望主線程開始之後,等待子線程運行結束,主線程繼續執行 考慮子線程是一個耗時的阻塞操作,我們需要通過程序讓子線程運行結束再執行主線程。這裏給出如下幾種解決辦法
①、t1.join()
②、while(t1.isAlive())
③、while(Thread.activeCount()>1)
④、CountDownLatch
-
方法一
t1.start();
後面接上t1.join()
-
方法二 判斷子線程是否還存活
-
方法三 判斷活躍的線程是否大於1
-
方法四 通過同步工具類
CountDownLatch
實現
這種辦法需要CountDownLatch對象侵入線程run()方法的代碼中。最終執行結果和前面幾種解決辦法一致
CountDownLatch通過await()方法阻塞主線程,等待其他線程運行結束,通過countDown()方法來釋放鎖,主線程開始執行。
總結:
一、二兩種辦法需要知道線程的名字,當有很多線程同時執行的時候,有時候,我們是無法直觀的知道每個線程的名字,這兩個辦法用的很少見。
第四種辦法在多線程的情況下也可以使用,就是需要設置CountDownLatch latch = new CountDownLatch(n)
,指定需要等待的線程數。
第三種辦法無需知道線程的名字和線程的數量,使用起來很直觀。