在上面的例子中多次使用到了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。