天天看點

Java 并發 —— 讀寫鎖(ReadWriteLock)

讀寫鎖(ReadWriteLock),顧名思義,就是在讀寫某檔案時,對該檔案上鎖。

1. ReentrantReadWriteLock

  • 三部曲:
    • 加鎖;
    • 讀寫操作;
    • 解鎖;(為保證解鎖操作一定執行,通常将其置于 finally 代碼段内)

2. 将讀寫鎖應用于集合類上

使得集合線程安全。一個線程安全的字典(map)如下:

class RWDictionary {

   private final Map<String, Data> m = new TreeMap<String, Data>();
   private final ReentrantReadWriteLock rwl = new ReentrantReadWriteLock();

   private final Lock r = rwl.readLock();
   private final Lock w = rwl.writeLock();

    public Data get(String key) {
     r.lock();
     try { return m.get(key); }
     finally { r.unlock(); }
   }

   public String[] allKeys() {
     r.lock();
     try { return m.keySet().toArray(); }
     finally { r.unlock(); }
   }

   public Data put(String key, Data value) {
     w.lock();
     try { return m.put(key, value); }
     finally { w.unlock(); }
   }

   public void clear() {
     w.lock();
     try { m.clear(); }
     finally { w.unlock(); }
   }

 }
           

繼續閱讀