2013年計(jì)算機(jī)二級(jí)Java多線程入門技巧(7)

字號(hào):

join方法的使用
    在上面的例子中多次使用到了Thread類的join方法。我想大家可能已經(jīng)猜出來(lái)join方法的功能是什么了。對(duì),join方法的功能就是使異步執(zhí)行的線程變成同步執(zhí)行。也就是說(shuō),當(dāng)調(diào)用線程實(shí)例的start方法后,這個(gè)方法會(huì)立即返回,如果在調(diào)用start方法后后需要使用一個(gè)由這個(gè)線程計(jì)算得到的值,就必須使用join方法。如果不使用join方法,就不能保證當(dāng)執(zhí)行到start方法后面的某條語(yǔ)句時(shí),這個(gè)線程一定會(huì)執(zhí)行完。而使用join方法后,直到這個(gè)線程退出,程序才會(huì)往下執(zhí)行。下面的代碼演示了join的用法。
    package mythread;
    2.
    3.public class JoinThread extends Thread
    4.{
    5. public static int n = 0;
    6.
    7. static synchronized void inc()
    8. {
    9. n++;
    10. }
    11. public void run()
    12. {
    13. for (int i = 0; i < 10; i++)
    14. try
    15. {
    16. inc();
    17. sleep(3); // 為了使運(yùn)行結(jié)果更隨機(jī),延遲3毫秒
    18.
    19. }
    20. catch (Exception e)
    21. {
    22. }
    23. }
    24. public static void main(String[] args) throws Exception
    25. {
    26.
    27. Thread threads[] = new Thread[100];
    28. for (int i = 0; i < threads.length; i++) // 建立100個(gè)線程
    29. threads[i] = new JoinThread();
    30. for (int i = 0; i < threads.length; i++) // 運(yùn)行剛才建立的100個(gè)線程
    31. threads[i].start();
    32. if (args.length > 0)
    33. for (int i = 0; i < threads.length; i++) // 100個(gè)線程都執(zhí)行完后繼續(xù)
    34. threads[i].join();
    35. System.out.println("n=" + JoinThread.n);
    36. }
    37.}
    在例程2-8中建立了100個(gè)線程,每個(gè)線程使靜態(tài)變量n增加10.如果在這100個(gè)線程都執(zhí)行完后輸出n,這個(gè)n值應(yīng)該是1000。
    測(cè)試1
    使用如下的命令運(yùn)行上面程序:
    38.java mythread.JoinThread
    程序的運(yùn)行結(jié)果如下
    n=442
    這個(gè)運(yùn)行結(jié)果可能在不同的運(yùn)行環(huán)境下有一些差異,但一般n不會(huì)等于1000.從上面的結(jié)果可以肯定,這100個(gè)線程并未都執(zhí)行完就將n輸出了。
    2. 測(cè)試2
    使用如下的命令運(yùn)行上面的代碼
    在上面的命令行中有一個(gè)參數(shù)join,其實(shí)在命令行中可以使用任何參數(shù),只要有一個(gè)參數(shù)就可以,這里使用join,只是為了表明要使用join方法使這100個(gè)線程同步執(zhí)行。
    程序的運(yùn)行結(jié)果如下:
    n=1000
    無(wú)論在什么樣的運(yùn)行環(huán)境下運(yùn)行上面的命令,都會(huì)得到相同的結(jié)果:n=1000.這充分說(shuō)明了這100個(gè)線程肯定是都執(zhí)行完了,因此,n一定會(huì)等于1000。