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

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

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

    瘋狂

    STANDING ON THE SHOULDERS OF GIANTS
    posts - 481, comments - 486, trackbacks - 0, articles - 1
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    ReadWriteLock

    Posted on 2011-10-17 16:59 瘋狂 閱讀(1130) 評論(0)  編輯  收藏 所屬分類: concurrent
         線程讀寫同一個對象的數據是很普遍的,通常,要避免讀寫沖突,必須保證任何時候僅有一個線程在寫入,有線程正在讀取的時候,寫入操作就必須等待。簡單說,就是要避免“寫-寫”沖突和“讀-寫”沖突。但是同時讀是允許的,因為“讀-讀”不沖突,而且很安全。
      沖jdk1.5開始可以使用ReadWriteLock類來防止讀寫沖突.它有一個已有的實現ReentrantReadWriteLock。
    ReentrantReadWriteLock使用內部維護的讀寫鎖來防止讀寫沖突;
     
      public ReentrantReadWriteLock.WriteLock writeLock() return writerLock; }
        
    public ReentrantReadWriteLock.ReadLock  readLock()  return readerLock; }
    示例代碼如下:

    public class RreadWriteLockTest {

      ReadWriteLock readWriteLock = new ReentrantReadWriteLock();
      public int i  = 0;
    //讀取
     public void read() throws InterruptedException{
      readWriteLock.readLock().lock();//獲取讀鎖
      System.out.println("read thread:"+Thread.currentThread().getName());
      Thread.sleep(10000);
      System.out.println("read:"+i);
      readWriteLock.readLock().unlock();
     }
    //寫入
     public void write() throws InterruptedException{
      
      readWriteLock.writeLock().lock();//獲取寫鎖
      System.out.println("write thread:"+Thread.currentThread().getName());
      Thread.sleep(10000);
      i = 2;
      System.out.println("write:"+i);
    readWriteLock.writeLock().unlock();
     }
    }
    測試代碼:
    1 測試兩個同時讀的,結果都能同時讀取。
    2 測試一個讀,一個寫的,需要其中一個釋放鎖之后才能進行另外一個操作
    public static void main(String[] args) throws InterruptedException {
      final RreadWriteLockTest lockTest= new RreadWriteLockTest();
      new Thread(new Runnable() {
       
       @Override
       public void run() {
        try {
         lockTest.write();
        } catch (InterruptedException e) {
         e.printStackTrace();
        }
       }
      }).start();
      Thread.sleep(2000);
     new Thread(new Runnable() {
        @Override
        public void run() {
         try {
          lockTest.read();
         } catch (InterruptedException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
         }
        }
       }).start();
     }
    打印如下:
    write thread:Thread-0執行完之后(10秒之后)才執行read thread:Thread-1

    注意:執行完以后一定要執行unlock,要不lock的計數沒有-1,這樣對應read或者write的操作將無法進行,一直等待。


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 最近中文字幕mv免费高清视频7 | 亚洲成人一区二区| 亚洲爆乳少妇无码激情| 1000部拍拍拍18勿入免费视频软件| 亚洲AV无码日韩AV无码导航| 美女在线视频观看影院免费天天看| 亚洲精品自产拍在线观看| a毛片免费全部在线播放**| 亚洲AV无码国产精品麻豆天美| 三年片在线观看免费西瓜视频| 亚洲s色大片在线观看| 一级毛片全部免费播放| 亚洲人成在线免费观看| 毛片a级毛片免费播放下载| 日本亚洲高清乱码中文在线观看| 免费va在线观看| 中国国产高清免费av片| 亚洲午夜精品一区二区| 国产免费不卡v片在线观看| 亚洲人av高清无码| 久久精品国产亚洲5555| 久久99热精品免费观看牛牛| 亚洲乱码在线播放| 五月天婷亚洲天综合网精品偷| 中文字幕版免费电影网站| 亚洲韩国在线一卡二卡| 午夜影视在线免费观看| 精品无码一级毛片免费视频观看| 亚洲网址在线观看你懂的| 免费高清在线影片一区| 精品熟女少妇aⅴ免费久久| 91嫩草亚洲精品| gogo全球高清大胆亚洲| 久久免费观看国产精品| 亚洲日韩精品国产一区二区三区 | 国产区图片区小说区亚洲区| 亚洲码国产精品高潮在线| 免费看韩国黄a片在线观看| 日韩免费码中文在线观看| 亚洲男人的天堂在线播放| 在线观看免费a∨网站|