一道多線程題目的解決方案

一道多線程題目的解決方案

 

在iteye上看到的一道多線程的題目,參考了一下網友的實現,那Eclipse調試經過,算是對JAVA5的併發庫有個大體的瞭解,分享出來,歡迎拍磚。html

題目:java

要求用三個線程,按順序打印1,2,3,4,5.... 71,72,73,74, 75.多線程

線程1先打印1,2,3,4,5, 而後是線程2打印6,7,8,9,10, 而後是線程3打印11,12,13,14,15. 接着再由線程1打印16,17,18,19,20....以此類推, 直到線程3打印到75。併發

分析:感受出題人是要考察一下你是否可以很好的控制多線程,讓他們有序的進行。ide

一、線程池:3個線程,須要使用併發庫的線程池post

二、鎖(lcok):在打印的時候,只容許一個線程進入,其餘的線程等待spa

下面的主要的代碼:.net

[java]  view plain  copy
 
  1. import java.util.HashMap;  
  2. import java.util.Map;  
  3. import java.util.concurrent.CountDownLatch;  
  4. import java.util.concurrent.ExecutorService;  
  5. import java.util.concurrent.Executors;  
  6. import java.util.concurrent.locks.Condition;  
  7. import java.util.concurrent.locks.Lock;  
  8. import java.util.concurrent.locks.ReentrantLock;  
  9.   
  10. public class NumberPrinter {  
  11.   
  12.     private Lock lock = new ReentrantLock();  
  13.   
  14.     private Condition c1 = lock.newCondition();  
  15.     private Condition c2 = lock.newCondition();  
  16.     private Condition c3 = lock.newCondition();  
  17.   
  18.     private Map<Integer, Condition> condtionContext =   
  19.         new HashMap<Integer, Condition>();  
  20.   
  21.     public NumberPrinter() {  
  22.         condtionContext.put(Integer.valueOf(0), c1);  
  23.         condtionContext.put(Integer.valueOf(1), c2);  
  24.         condtionContext.put(Integer.valueOf(2), c3);  
  25.     }  
  26.       
  27.     private int count = 0;     
  28.       
  29.     public void print(int id) {  
  30.         lock.lock();  
  31.         try {  
  32.             while(count*5 < 75) {  
  33.                 int curID = calcID();  
  34.                 if (id == curID) {  
  35.                     for (int i = 1; i<=5; i++) {  
  36.                         System.out.print(count*5 +i+ ",");  
  37.                     }  
  38.                     System.out.println();  
  39.                     count++;  
  40.                     int nextID = calcID();  
  41.                     Condition nextCondition = condtionContext.get(  
  42.                             Integer.valueOf(nextID));  
  43.                     //通知下一線程  
  44.                     nextCondition.signal();  
  45.                 } else {  
  46.                     Condition condition = condtionContext.get(  
  47.                             Integer.valueOf(id));  
  48.                     condition.await();  
  49.                 }  
  50.             }  
  51.             //通知線程結束  
  52.             for(Condition c : condtionContext.values()) {  
  53.                 c.signal();  
  54.             }  
  55.         } catch (Exception e) {  
  56.             e.printStackTrace();  
  57.         } finally {  
  58.             lock.unlock();  
  59.         }  
  60.     }  
  61.   
  62.       
  63.     private int calcID() {  
  64.         // TODO Auto-generated method stub  
  65.         return count % 3;  
  66.     }  
  67.   
  68.   
  69.     /** 
  70.      * @param args 
  71.      */  
  72.     public static void main(String[] args) {  
  73.         ExecutorService executor = Executors.newFixedThreadPool(3);  
  74.         final CountDownLatch latch = new CountDownLatch(1);     
  75.         final NumberPrinter printer = new NumberPrinter();   
  76.         for (int i = 0; i < 3; i++) {     
  77.             final int id = i;  
  78.             executor.submit(new Runnable() {  
  79.                 @Override  
  80.                 public void run() {  
  81.                     // TODO Auto-generated method stub  
  82.                     try {  
  83.                         latch.await();  
  84.                     } catch (InterruptedException e) {  
  85.                         // TODO Auto-generated catch block  
  86.                         e.printStackTrace();  
  87.                     }  
  88.                       
  89.                     printer.print(id);  
  90.                 }  
  91.                   
  92.             });  
  93.         }  
  94.           
  95.         System.out.println("三個任務開始順序打印數字。。。。。。");   
  96.         latch.countDown();  
  97.         executor.shutdown();  
  98.     }  
  99.   
  100. }  
相關文章
相關標籤/搜索