国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

Java多線程編程之讀寫鎖ReadWriteLock用法實例

2019-11-26 15:11:40
字體:
來源:轉載
供稿:網友

讀寫鎖:分為讀鎖和寫鎖,多個讀鎖不互斥,讀鎖與寫鎖互斥,這是由jvm自己控制的,你只要上好相應的鎖即可。如果你的代碼只讀數據,可以很多人同時讀,但不能同時寫,那就上讀鎖;如果你的代碼修改數據,只能有一個人在寫,且不能同時讀取,那就上寫鎖。總之,讀的時候上讀鎖,寫的時候上寫鎖!

三個線程讀數據,三個線程寫數據示例:
可以同時讀,讀的時候不能寫,不能同時寫,寫的時候不能讀。
讀的時候上讀鎖,讀完解鎖;寫的時候上寫鎖,寫完解鎖。
注意finally解鎖。

package com.ljq.test.thread; import java.util.Random;import java.util.concurrent.locks.ReadWriteLock;import java.util.concurrent.locks.ReentrantReadWriteLock; /** * 讀寫鎖 * * @author Administrator * */public class ReadWriteLockTest {  public static void main(String[] args) {    final ReadWrite rw = new ReadWrite();    for (int i = 0; i < 3; i++) {      new Thread() {        public void run() {          while (true) {            rw.read();          }        }       }.start();       new Thread() {        public void run() {          while (true) {            rw.write(new Random().nextInt(10000));          }        }       }.start();    }   }} /** * 讀和寫要互斥,因此要把它們放在同一個類中 * * @author Administrator * */class ReadWrite {  private Object data = null;//共享數據,只能有一個線程寫該數據,但可以有多個線程同時讀該數據。  ReadWriteLock rwl = new ReentrantReadWriteLock();   /**   * 讀數據   */  public void read() {         rwl.readLock().lock();    try {      System.out.println(Thread.currentThread().getName() + " be ready to read data!");      Thread.sleep((long) (Math.random() * 1000));      System.out.println(Thread.currentThread().getName() + "have read data :" + data);    } catch (InterruptedException e) {      e.printStackTrace();    } finally {      rwl.readLock().unlock();    }       }   /**   * 寫數據   *   * @param data   */  public void write(Object data) {         rwl.writeLock().lock();    try {      System.out.println(Thread.currentThread().getName() + " be ready to write data!");      Thread.sleep((long) (Math.random() * 1000));      this.data = data;      System.out.println(Thread.currentThread().getName() + " have write data: " + data);    } catch (InterruptedException e) {      e.printStackTrace();    } finally {      rwl.writeLock().unlock();    }   }}

設計一個緩存系統
緩存系統:你要取數據,需調用我的public Object getData(String key)方法,我要檢查我內部有沒有這個數據,如果有就直接返回,如果沒有,就從數據庫中查找這個數,查到后將這個數據存入我內部的存儲器中,下次再有人來要這個數據,我就直接返回這個數不用再到數據庫中找了。你要取數據不要找數據庫,來找我。

package com.ljq.test.thread; import java.util.HashMap;import java.util.Map;import java.util.concurrent.locks.ReadWriteLock;import java.util.concurrent.locks.ReentrantReadWriteLock; /** * 設計一個緩存系統 * * * @author Administrator * */public class CacheDemo {   private Map<String, Object> cache = new HashMap<String, Object>();   public static void main(String[] args) {    String key = "name";    CacheDemo cacheDemo = new CacheDemo();    System.out.println(cacheDemo.getData(key)); //從數據庫獲取數據    System.out.println(cacheDemo.getData(key)); //從緩存獲取數據    System.out.println(cacheDemo.getData(key)); //從緩存獲取數據  }   private ReadWriteLock rwl = new ReentrantReadWriteLock();   public Object getData(String key) {    rwl.readLock().lock(); //上讀鎖    Object value = null;    try {      value = cache.get(key); //先查詢內部存儲器中有沒有要的值      if (value == null) { //如果沒有,就去數據庫中查詢,并將查到的結果存入內部存儲器中        //釋放讀鎖、上寫鎖        rwl.readLock().unlock();        rwl.writeLock().lock();        try {          if (value == null) { //再次進行判斷,防止多個寫線程堵在這個地方重復寫            System.out.println("read data from database");            value = "張三";            cache.put(key, value);          }        } finally {          //設置完成 釋放寫鎖          rwl.writeLock().unlock();        }        //恢復讀寫狀態        rwl.readLock().lock();      }else{        System.out.println("read data from cache");      }    } finally {      rwl.readLock().unlock(); //釋放讀鎖    }    return value;  }}

返回結果:

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 上饶县| 鹤峰县| 榆中县| 镇平县| 南宁市| 鄂托克旗| 沧州市| 肇州县| 庆云县| 泸西县| 顺义区| 固安县| 特克斯县| 萨嘎县| 墨江| 沁水县| 三都| 义乌市| 屏山县| 克山县| 安龙县| 长海县| 安福县| 新丰县| 山阳县| 井陉县| 东港市| 尉犁县| 海林市| 禹州市| 丹江口市| 孟津县| 京山县| 金溪县| 宁强县| 平度市| 宾阳县| 平度市| 安泽县| 遂川县| 东乌珠穆沁旗|