在上面的例子中多次使用到了Thread類的join方法。我想大家可能已經猜出來join方法的功能是什麼了。對,join方法的功能就是使異步執行的線程變成同步執行。也就是說,當調用線程實例的start方法後,這個方法會立即返回,如果在調用start方法後後需要使用一個由這個線程計算得到的值,就必須使用join方法。如果不使用join方法,就不能保證當執行到start方法後面的某條語句時,這個線程一定會執行完。而使用join方法後,直到這個線程退出,程序才會往下執行。下面的代碼演示了join的用法。
package mythread;
public class JoinThread extends Thread
{
public static volatile int n = 0;
public void run()
{
for (int i = 0; i < 10; i++, n++)
try
{
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。