自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

為什么要用讀寫鎖?它有什么優(yōu)點?

開發(fā) 前端
在以上代碼中,利用上述的工具類型,我們就可以輕松地提取 User 對象類型中函數(shù)類型和非函數(shù)類型的屬性及相關(guān)的對象類型。

讀寫鎖(Readers-Writer Lock)顧名思義是一把鎖分為兩部分:讀鎖和寫鎖,其中讀鎖允許多個線程同時獲得,因為讀操作本身是線程安全的,而寫鎖則是互斥鎖,不允許多個線程同時獲得寫鎖,并且寫操作和讀操作也是互斥的。總結(jié)來說,讀寫鎖的特點是:讀讀不互斥、讀寫互斥、寫寫互斥。

1.讀寫鎖使用

在 Java 語言中,讀寫鎖是使用 ReentrantReadWriteLock 類來實現(xiàn)的,其中:

  • ReentrantReadWriteLock.ReadLock 表示讀鎖,它提供了 lock 方法進行加鎖、unlock 方法進行解鎖。
  • ReentrantReadWriteLock.WriteLock 表示寫鎖,它提供了 lock 方法進行加鎖、unlock 方法進行解鎖。

它的基礎(chǔ)使用如下代碼所示:

// 創(chuàng)建讀寫鎖
final ReentrantReadWriteLock readWriteLock = new ReentrantReadWriteLock();
// 獲得讀鎖
final ReentrantReadWriteLock.ReadLock readLock = readWriteLock.readLock();
// 獲得寫鎖
final ReentrantReadWriteLock.WriteLock writeLock = readWriteLock.writeLock();
// 讀鎖使用
readLock.lock();
try {
// 業(yè)務(wù)代碼...
} finally {
readLock.unlock();
}
// 寫鎖使用
writeLock.lock();
try {
// 業(yè)務(wù)代碼...
} finally {
writeLock.unlock();
}

1.1 讀讀不互斥

多個線程可以同時獲取到讀鎖,稱之為讀讀不互斥,如下代碼所示:

// 創(chuàng)建讀寫鎖
final ReentrantReadWriteLock readWriteLock = new ReentrantReadWriteLock();
// 創(chuàng)建讀鎖
final ReentrantReadWriteLock.ReadLock readLock = readWriteLock.readLock();
Thread t1 = new Thread(() -> {
readLock.lock();
try {
System.out.println("[t1]得到讀鎖.");
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
System.out.println("[t1]釋放讀鎖.");
readLock.unlock();
}
});
t1.start();
Thread t2 = new Thread(() -> {
readLock.lock();
try {
System.out.println("[t2]得到讀鎖.");
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
System.out.println("[t2]釋放讀鎖.");
readLock.unlock();
}
});
t2.start();

以上程序執(zhí)行結(jié)果如下:

1.2 讀寫互斥

讀鎖和寫鎖同時使用是互斥的(也就是不能同時獲得),這稱之為讀寫互斥,如下代碼所示:

// 創(chuàng)建讀寫鎖
final ReentrantReadWriteLock readWriteLock = new ReentrantReadWriteLock();
// 創(chuàng)建讀鎖
final ReentrantReadWriteLock.ReadLock readLock = readWriteLock.readLock();
// 創(chuàng)建寫鎖
final ReentrantReadWriteLock.WriteLock writeLock = readWriteLock.writeLock();
// 使用讀鎖
Thread t1 = new Thread(() -> {
readLock.lock();
try {
System.out.println("[t1]得到讀鎖.");
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
System.out.println("[t1]釋放讀鎖.");
readLock.unlock();
}
});
t1.start();
// 使用寫鎖
Thread t2 = new Thread(() -> {
writeLock.lock();
try {
System.out.println("[t2]得到寫鎖.");
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
System.out.println("[t2]釋放寫鎖.");
writeLock.unlock();
}
});
t2.start();

以上程序執(zhí)行結(jié)果如下:

1.3 寫寫互斥

多個線程同時使用寫鎖也是互斥的,這稱之為寫寫互斥,如下代碼所示:

// 創(chuàng)建讀寫鎖
final ReentrantReadWriteLock readWriteLock = new ReentrantReadWriteLock();
// 創(chuàng)建寫鎖
final ReentrantReadWriteLock.WriteLock writeLock = readWriteLock.writeLock();
Thread t1 = new Thread(() -> {
writeLock.lock();
try {
System.out.println("[t1]得到寫鎖.");
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
System.out.println("[t1]釋放寫鎖.");
writeLock.unlock();
}
});
t1.start();

Thread t2 = new Thread(() -> {
writeLock.lock();
try {
System.out.println("[t2]得到寫鎖.");
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
System.out.println("[t2]釋放寫鎖.");
writeLock.unlock();
}
});
t2.start();

以上程序執(zhí)行結(jié)果如下:

2.優(yōu)點分析

提高了程序執(zhí)行性能:多個讀鎖可以同時執(zhí)行,相比于普通鎖在任何情況下都要排隊執(zhí)行來說,讀寫鎖提高了程序的執(zhí)行性能。

避免讀到臨時數(shù)據(jù):讀鎖和寫鎖是互斥排隊執(zhí)行的,這樣可以保證了讀取操作不會讀到寫了一半的臨時數(shù)據(jù)。

3.適用場景

讀寫鎖適合多讀少寫的業(yè)務(wù)場景,此時讀寫鎖的優(yōu)勢最大。

總結(jié)

讀寫鎖是一把鎖分為兩部分:讀鎖和寫鎖,其中讀鎖允許多個線程同時獲得,而寫鎖則是互斥鎖。它的完整規(guī)則是:讀讀不互斥、讀寫互斥、寫寫互斥。它適用于多讀的業(yè)務(wù)場景,使用它可以有效的提高程序的執(zhí)行性能,也能避免讀取到操作了一半的臨時數(shù)據(jù)。

責任編輯:武曉燕 來源: Java面試真題解析
相關(guān)推薦

2022-07-13 07:06:47

HTTPSHTTP協(xié)議

2009-01-09 23:06:41

服務(wù)器SCSI硬盤PC

2020-04-07 16:12:56

Go編程語言開發(fā)

2023-12-21 21:39:44

2024-05-15 09:41:22

樂觀鎖編程

2021-05-11 06:57:15

HBaseBATJ公司

2024-07-02 13:27:38

2021-12-13 01:40:29

ElasticSear倒排索引

2024-01-02 17:28:12

芯片CPUAI計算

2015-07-01 10:25:07

Docker開源項目容器

2023-09-22 10:05:32

2016-01-12 16:58:31

C游戲

2022-07-06 09:29:40

JMH性能測試

2023-12-06 09:10:28

JWT微服務(wù)

2012-12-12 10:05:05

產(chǎn)品項目

2024-06-11 00:01:00

并發(fā)validate場景

2023-09-19 16:37:47

網(wǎng)絡(luò)

2021-07-26 18:38:48

Bpmn流程

2024-06-19 10:26:36

非阻塞IO客戶端

2020-11-19 07:38:57

邊緣計算
點贊
收藏

51CTO技術(shù)棧公眾號