<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 啥都寫點 閱讀(449) 評論(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();
        }

    }


                                                                                                           --    學海無涯
            

    主站蜘蛛池模板: 在线播放高清国语自产拍免费| 丰满人妻一区二区三区免费视频| 中文字幕在线亚洲精品| 亚洲 日韩 色 图网站| 国产精品成人69XXX免费视频| www亚洲一级视频com| 国产成人综合亚洲绿色| 免费吃奶摸下激烈视频| 真人无码作爱免费视频| 日本人的色道www免费一区| 亚洲AV人人澡人人爽人人夜夜| a级片免费观看视频| 亚洲精品自在在线观看| 久章草在线精品视频免费观看| 亚洲伊人tv综合网色| 精品久久8x国产免费观看| 亚洲午夜精品在线| 国产中文字幕在线免费观看| 国产亚洲AV无码AV男人的天堂| 日本亚洲欧洲免费天堂午夜看片女人员| 亚洲AV人人澡人人爽人人夜夜| 97青青草原国产免费观看| 亚洲免费视频观看| 韩国二级毛片免费播放| 九九视频高清视频免费观看| 日韩免费视频网站| 高清免费久久午夜精品 | 中出五十路免费视频| 亚洲欧洲第一a在线观看| eeuss免费影院| 亚洲国产精品线在线观看| 成年女人毛片免费播放人| 五月天婷婷免费视频| 亚洲成aⅴ人在线观看| 毛片免费在线观看网站| 免费大片av手机看片| 国产成人精品久久亚洲| 0588影视手机免费看片| 人人狠狠综合久久亚洲| 亚洲精品国产综合久久一线| 亚洲精品乱码久久久久久蜜桃图片|