<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Cyh的博客

    Email:kissyan4916@163.com
    posts - 26, comments - 19, trackbacks - 0, articles - 220

    線程--Semaphore

    Posted on 2009-12-23 23:14 啥都寫點 閱讀(454) 評論(0)  編輯  收藏 所屬分類: J2SE

       本例介紹第一個同步裝置:Semaphore,它是一個用來管理資源池的工具,可以看成是個通行證,線程想要從資源池拿到資源必須先拿到通行證,如果線程暫時拿不到通行證,線程就會被阻斷,進入等待狀態。

         在構造Semaphore對象時,必須提供通行證的數目,如"new Semaphore(3)"將創建一個具有3個通行證的Semaphore對象,一旦該對象被創建,其通行證數量是不能改變的。
         Semaphore的acquire方法取得一個通行證,如果通行證已經發完了,當前線程將進入等待狀態,直到有其他線程釋放了通行證。
         Semaphore的release方法釋放資源池。


    import java.util.ArrayList;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    import java.util.concurrent.Semaphore;
    import java.util.concurrent.locks.Lock;
    import java.util.concurrent.locks.ReentrantLock;

    /**
     * Java 5.0里新加了4個協調線程間進程的同步裝置,它們分別是:
     * Semaphore, CountDownLatch, CyclicBarrier和Exchanger.
     * 本例主要介紹Semaphore。
     * Semaphore是用來管理一個資源池的工具,可以看成是個通行證,
     * 線程要想從資源池拿到資源必須先拿到通行證,
     * 如果線程暫時拿不到通行證,線程就會被阻斷進入等待狀態。
     
    */

    public class SemaphoreTest {
        
    /**
         * 模擬資源池的類
         * 只為池發放2個通行證,即同時只允許2個線程獲得池中的資源。
         
    */

        
    public static class Pool {
            
    // 保存資源池中的資源
            ArrayList<String> pool = null;
            
    // 通行證
            Semaphore pass = null;
            Lock lock 
    = new ReentrantLock();
            
    public Pool(int size) {
                
    // 初始化資源池
                pool = new ArrayList<String>();
                
    for (int i = 0; i < size; i++{
                    pool.add(
    "Resource " + i);
                }

                
    // 發放2個通行證
                pass = new Semaphore(2);
            }


            
    public String get() throws InterruptedException {
                
    // 獲取通行證,只有得到通行證后才能得到資源
                System.out.println("Try to get a pass");
                pass.acquire();
                System.out.println(
    "Got a pass");
                
    return getResource();
            }


            
    public void put(String resource) {
                
    // 歸還通行證,并歸還資源
                System.out.println("Released a pass");
                pass.release();
                releaseResource(resource);
            }


            
    private String getResource() {
                lock.lock();
                String result 
    = pool.remove(0);
                System.out.println(
    "資源 " + result + " 被取走");
                lock.unlock();
                
    return result;
            }


            
    private void releaseResource(String resource) {
                lock.lock();
                System.out.println(
    "資源 " + resource + " 被歸還");
                pool.add(resource);
                lock.unlock();
            }
     
        }

        
        
    public static void testPool() {
            
    // 準備10個資源的資源池
            final Pool aPool = new Pool(10);
            Runnable worker 
    = new Runnable() {
                
    public void run() {
                    String resource 
    = null;
                    
    try {
                        
    //取得resource
                        resource = aPool.get();
                        
    //用resource做工作
                        System.out.println("I am working on " + resource);
                        Thread.sleep(
    500);
                        System.out.println(
    "I finished on " + resource);
                    }
     catch (InterruptedException ex) {
                    }

                    
    //歸還resource
                    aPool.put(resource);
                }

            }
    ;
            
    // 啟動5個任務
            ExecutorService service = Executors.newCachedThreadPool();
            
    for (int i = 0; i < 5; i++{
                service.submit(worker);
            }

            service.shutdown();
        }
     
        
        
    public static void main(String[] args) {
            SemaphoreTest.testPool();
        }

    }


                                                                                                           --    學海無涯
            

    主站蜘蛛池模板: 免费人成无码大片在线观看| 曰批全过程免费视频网址| 日韩免费一级毛片| 亚洲人成网站18禁止久久影院 | 伊伊人成亚洲综合人网7777| 黄网站色视频免费观看45分钟| 国产在线a不卡免费视频| 精品亚洲福利一区二区| 免费在线观看黄网| eeuss免费影院| 亚洲成AV人片在线观看无码| 一区二区在线免费观看| 久久亚洲日韩精品一区二区三区| 日韩在线永久免费播放| 亚洲国产精品网站久久| 影音先锋在线免费观看| 美女尿口扒开图片免费| 亚洲人成伊人成综合网久久久 | 亚洲欧洲专线一区| 又色又污又黄无遮挡的免费视| 一级**爱片免费视频| 久久久综合亚洲色一区二区三区 | 一级毛片免费不卡在线| 亚洲性一级理论片在线观看| 女性自慰aⅴ片高清免费| 男人扒开添女人下部免费视频| 亚洲精品二区国产综合野狼| 91视频免费网址| 亚洲一本到无码av中文字幕| 亚洲无码精品浪潮| 亚洲成人免费在线| 亚洲国产区男人本色在线观看| 亚洲国产成人影院播放| 在线涩涩免费观看国产精品 | 中文字幕在线亚洲精品 | 日本免费一区二区三区四区五六区| 亚洲w码欧洲s码免费| 国产伦精品一区二区三区免费迷| A级毛片成人网站免费看| 在线观看亚洲一区二区| 国产一区在线观看免费|