在上面的範例中多次使用到了Thread類別的join方法。我想大家可能已經猜出來join方法的功能是什麼了。對,join方法的功能就是讓非同步執行的執行緒變成同步執行。也就是說,當呼叫執行緒實例的start方法後,這個方法會立即傳回,如果在呼叫start方法後後需要使用這個執行緒計算得到的值,就必須使用join方法。如果不使用join方法,就無法保證當執行到start方法後面的某條語句時,這個執行緒一定會執行完。而使用join方法後,直到這個執行緒退出,程式才會往下執行。下面的程式碼示範了join的用法。
複製代碼代碼如下:
package mythread;
public class JoinThread extends Thread
{
public static int n = 0;
static synchronized void inc()
{
n++;
}
public void run()
{
for (int i = 0; i < 10; i++)
try
{
inc();
sleep(3); // 為了讓運作結果更隨機,延遲3毫秒
}
catch (Exception e)
{
}
}
public static void main(String[] args) throws Exception
{
Thread threads[] = new Thread[100];
for (int i = 0; i < threads.length; i++) // 建立100個線程
threads[i] = new JoinThread();
for (int i = 0; i < threads.length; i++) // 執行剛才建立的100個執行緒
threads[i].start();
if (args.length > 0)
for (int i = 0; i < threads.length; i++) // 100個執行緒都執行完後繼續
threads[i].join();
System.out.println("n=" + JoinThread.n);
}
}
在例程2-8中建立了100個線程,每個線程都使靜態變數n增加10。如果這100個執行緒都執行完後輸出n,這個n值應該是1000。
1. 測試1
使用如下的命令運行上面程式:
複製代碼代碼如下:
java mythread.JoinThread
程式的運行結果如下:
複製代碼代碼如下:
n=442
這個運行結果可能在不同的運行環境下有一些差異,但一般n不會等於1000。從上面的結果可以肯定,這100個執行緒並未都執行完就將n輸出了。
2. 測試2
使用如下的命令運行上面的程式碼:
在上面的命令列中有一個參數join,其實在命令列中可以使用任何參數,只要有一個參數就可以,這裡使用join,只是為了表明要使用join方法使這100個線程同步執行。
程式的運行結果如下:
複製代碼代碼如下:
n=1000
無論在什麼樣的運行環境下執行上面的命令,都會得到相同的結果:n=1000。這充分說明了這100個執行緒肯定是都執行完了,因此,n一定會等於1000。