java多線程編程之join方法的使用示例
在上面的例子中多次使用到了Thread類的join方法。我想大家可能已經(jīng)猜出來join方法的功能是什么了。對,join方法的功能就是使異步執(zhí)行的線程變成同步執(zhí)行。也就是說,當調(diào)用線程實例的start方法后,這個方法會立即返回,如果在調(diào)用start方法后后需要使用一個由這個線程計算得到的值,就必須使用join方法。如果不使用join方法,就不能保證當執(zhí)行到start方法后面的某條語句時,這個線程一定會執(zhí)行完。而使用join方法后,直到這個線程退出,程序才會往下執(zhí)行。下面的代碼演示了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個線程都執(zhí)行完后繼續(xù)
threads[i].join();
System.out.println("n=" + JoinThread.n);
}
}
在例程2-8中建立了100個線程,每個線程使靜態(tài)變量n增加10。如果在這100個線程都執(zhí)行完后輸出n,這個n值應該是1000。
1. 測試1
使用如下的命令運行上面程序:
java mythread.JoinThread
程序的運行結果如下:
n=442
這個運行結果可能在不同的運行環(huán)境下有一些差異,但一般n不會等于1000。從上面的結果可以肯定,這100個線程并未都執(zhí)行完就將n輸出了。
2. 測試2
使用如下的命令運行上面的代碼:
在上面的命令行中有一個參數(shù)join,其實在命令行中可以使用任何參數(shù),只要有一個參數(shù)就可以,這里使用join,只是為了表明要使用join方法使這100個線程同步執(zhí)行。
程序的運行結果如下:
n=1000
無論在什么樣的運行環(huán)境下運行上面的命令,都會得到相同的結果:n=1000。這充分說明了這100個線程肯定是都執(zhí)行完了,因此,n一定會等于1000。
相關文章
基于springboot redirect重定向路徑問題總結
這篇文章主要介紹了springboot redirect重定向路徑問題總結,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09java編程下字符串的16位,32位md5加密實現(xiàn)方法
下面小編就為大家?guī)硪黄猨ava編程下字符串的16位,32位md5加密實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09springboot高并發(fā)下提高吞吐量的實現(xiàn)
這篇文章主要介紹了springboot高并發(fā)下提高吞吐量的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-11-11Java Web使用簡單的批處理操作(記事本+Tomcat)
這篇文章主要介紹了Java Web使用簡單的批處理操作 ,需要的朋友可以參考下2014-10-10