JUC-ReadWriteLock
生活随笔
收集整理的這篇文章主要介紹了
JUC-ReadWriteLock
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
ReadWriteLock 維護了一對相關的鎖,一個用于只讀操作,另一個用于寫入操作。只要沒有 writer,讀取鎖可以由多個 reader 線程同時保持。寫入鎖是獨占的。
?
ReadWriteLock 讀取操作通常不會改變共享資源,但執行寫入操作時,必須獨占方式來獲取鎖。
對于讀取操作占多數的數據結構。ReadWriteLock 能提供比獨占鎖更高的并發性。
而對于只讀的數據結構,其中包含的不變性可以完全不需要考慮加鎖操作。
?
ReadWriteLock實際上是一種樂觀鎖。
對于一個線程來說,讀取數據不需要線程安全,寫數據需要線程安全。因此如果讀操作也只能一次只有一個線程操作,那么性能就浪費了,為此有了讀寫鎖。
正常的鎖,一次只能有一個線程操作。
讀寫鎖:分為讀鎖和寫鎖。
讀鎖:可以多個讀線程并發持有,一次能夠有n多線程同時執行。
寫鎖:跟普通鎖一樣,是獨占的,一次只能有一個線程進行寫操作。
這樣可以提高并發效率。
使用場景:
- 寫寫/讀寫 操作:需要互斥。
- 讀讀操作:不需要互斥。
初始化:
ReadWriteLock lock = new ReentrantReadWriteLock();讀鎖上鎖:
lock.readLock().lock(); //上鎖寫鎖上鎖:
lock.writeLock().lock();代碼:
package com.atguigu.juc;import java.util.concurrent.locks.ReadWriteLock; import java.util.concurrent.locks.ReentrantReadWriteLock;/** 1. ReadWriteLock : 讀寫鎖* * 寫寫/讀寫 需要“互斥”* 讀讀 不需要互斥*/ public class TestReadWriteLock {public static void main(String[] args) {ReadWriteLockDemo rw = new ReadWriteLockDemo();new Thread(new Runnable() {@Overridepublic void run() {rw.set((int)(Math.random() * 101));}}, "Write:").start();for (int i = 0; i < 100; i++) {new Thread(new Runnable() {@Overridepublic void run() {rw.get();}}).start();}} }class ReadWriteLockDemo{private int number = 0;private ReadWriteLock lock = new ReentrantReadWriteLock();//讀public void get(){lock.readLock().lock(); //上鎖try{System.out.println(Thread.currentThread().getName() + " : " + number);}finally{lock.readLock().unlock(); //釋放鎖 }}//寫public void set(int number){lock.writeLock().lock();try{System.out.println(Thread.currentThread().getName());this.number = number;}finally{lock.writeLock().unlock();}} }?
總結
以上是生活随笔為你收集整理的JUC-ReadWriteLock的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【WPF】MVVM模式的3种comman
- 下一篇: haproxy调度web案例