Java主線程等待所有子線程執行完畢再執行解決辦法(轉)


方法一:

Thread.join()方法,親測可行,thread.join()方法

 

[java]  view plain  copy
 
  1. Vector<Thread> ts = new Vector<Thread>();  
  2.         for (int i = 0; i < 200; i++) {  
  3.             Thread t = new Thread(new Runnable() {  
  4.                 @Override  
  5.                 public void run() {  
  6.                     Counter.inc();  
  7.                 }  
  8.             });  
  9.             ts.add(t);  
  10.             t.start();  
  11.         }  
  12.         for (Thread t : ts) {  
  13.             try {  
  14.                 t.join();  
  15.             } catch (InterruptedException e) {  
  16.                 // TODO Auto-generated catch block  
  17.                 e.printStackTrace();  
  18.             }  
  19.         }  
  20.           
  21.         System.out.println("----------" + Counter.count);  


(全部代碼見上一篇文章)

 

這個循環中的join的意思是:子線程排好隊,歡迎新同學main線程,main線程對着排好隊的他們說,我站你后邊,我站你后邊,我站你后邊。。。。(ts.size()次)。然后站到最后一個的后面了。恩、

 

方法二:

用線程池。

代碼:

[java]  view plain  copy
 
  1. ExecutorService threadPool = Executors.newScheduledThreadPool(10);  
  2.         ExecutorService threadPool = Executors.newCachedThreadPool();  
  3. for (int i = 0; i < 200; i++) {  
  4.     threadPool.execute(new Runnable() {  
  5.   
  6.         @Override  
  7.         public void run() {  
  8.             chi.inc();  
  9.         }  
  10.     });  
  11. }  
  12. threadPool.shutdownNow();  
  13. try {  
  14.     threadPool.awaitTermination(3, TimeUnit.MICROSECONDS);  
  15. catch (InterruptedException e) {  
  16.     e.printStackTrace();  
  17. }  
  18. System.out.println("------" + chi.count);  

 

 

Executors是個工廠,(工廠模式),創建出幾種不同類別的線程池。這里我用ScheduledThreadPool。(因為好使,注釋掉的那種不知為什么不管用)。

然后用shutdownNow(),這個方法是馬上停止(試圖)正在執行的任務,線程池進入STOP狀態,不再開啟正在等待的線程。

對比的,shutdown()方法是阻止等待中的進程開啟,等待所有正在執行的進程完成。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM