開發中遇到并發的問題一般會用到鎖,Synchronized存在明顯的一個性能問題就是讀與讀之間互斥;ReadWriteLock是JDK5中提供的讀寫分離鎖,讀寫分離鎖可以有效地幫助減少鎖競爭,以提升系統的性能,
ReadWriteLock管理一組鎖,一個是只讀的鎖,一個是寫鎖,
Java并發庫中ReetrantReadWriteLock實作了ReadWriteLock介面并添加了可重入的特性,
而讀寫鎖ReentrantReadWriteLock:讀讀共享,讀寫互斥,寫寫互斥;讀寫鎖維護了一對鎖,一個讀鎖,一個寫鎖,通過分離讀鎖和寫鎖,使得并發性相比一般的排他鎖有了很大提升,在讀多寫少的情況下,讀寫鎖能夠提供比排他鎖更好的并發性和吞吐量,

從原始碼中可以看出,讀寫鎖中同樣依賴佇列同步器Sync(AQS)實作同步功能,而讀寫狀態就是其同步器的同步狀態,下面從例子中來說明:讀讀共享,讀寫互斥,寫寫互斥,
代碼如下:
public class ReentrantWriteReadLockTest {
ReentrantReadWriteLock lock = new ReentrantReadWriteLock();
ReadLock readLock = lock.readLock();
WriteLock writeLock = lock.writeLock();
public void read(){
try {
readLock.lock();
System.out.println("執行緒"+Thread.currentThread().getName()+"進入,,,");
Thread.sleep(3000);
System.out.println("執行緒"+Thread.currentThread().getName()+"退出,,,");
} catch (InterruptedException e) {
e.printStackTrace();
}finally{
readLock.unlock();
}
}
public void write(){
try {
writeLock.lock();
System.out.println("執行緒"+Thread.currentThread().getName()+"進入,,,");
Thread.sleep(3000);
System.out.println("執行緒"+Thread.currentThread().getName()+"退出,,,");
} catch (InterruptedException e) {
e.printStackTrace();
}finally{
writeLock.unlock();
}
}
public static void main(String[] args) {
final ReentrantWriteReadLockTest wr = new ReentrantWriteReadLockTest();
Thread t1 = new Thread(new Runnable() {
public void run() {
wr.read();
}
}, "t1");
Thread t2 = new Thread(new Runnable() {
public void run() {
wr.read();
}
}, "t2");
Thread t3 = new Thread(new Runnable() {
public void run() {
wr.write();
}
}, "t3");
Thread t4 = new Thread(new Runnable() {
public void run() {
wr.write();
}
}, "t4");
t1.start();
t2.start();
//t3.start();
//t4.start();
}
}
當我們啟動執行緒t1和t2時,結果如下:

執行緒t1和t2可以同時進入,說明了讀讀共享!
當我們啟動執行緒t2和t3時,結果如下:

一個執行緒必須等待另一個執行緒退出,才能進入,說明了讀寫互斥!
當我們啟動執行緒t3和t4時,結果如下:

一個執行緒必須等待另一個執行緒退出,才能進入,說明了寫寫互斥!
來源:https://www.cnblogs.com/liuqing576598117/p/11168528.html
近期熱文推薦:
1.1,000+ 道 Java面試題及答案整理(2022最新版)
2.勁爆!Java 協程要來了,,,
3.Spring Boot 2.x 教程,太全了!
4.別再寫滿屏的爆爆爆炸類了,試試裝飾器模式,這才是優雅的方式!!
5.《Java開發手冊(嵩山版)》最新發布,速速下載!
覺得不錯,別忘了隨手點贊+轉發哦!
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/444314.html
標籤:Java
