JUC并发编程学习笔记(八)读写锁
生活随笔
收集整理的這篇文章主要介紹了
JUC并发编程学习笔记(八)读写锁
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
讀寫鎖
ReadWriteLock
ReadWriteLock只存在一個(gè)實(shí)現(xiàn)類那就是ReentrantReadWriteLock,他可以對鎖實(shí)現(xiàn)更加細(xì)粒化的控制
讀的時(shí)候可以有多個(gè)閱讀器線程同時(shí)參與,寫的時(shí)候只希望寫入線程是獨(dú)占的
Demo:
package org.example.rw;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.Semaphore;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;
public class ReadWriteLockDemo {
/*
* 讀讀 - 可以共存 (共享鎖)
* 讀寫 - 不能共存 (獨(dú)占鎖)
* 寫寫 - 不能共存 (獨(dú)占鎖)
* */
public static void main(String[] args) {
MyCache myCache = new MyCache();
// 寫入:要求在寫入時(shí)不能存在插隊(duì)的情況,以防止寫入時(shí)資源被搶占
for (int i = 1; i <= 5; i++) {
final int temp = i;
new Thread(()->{
myCache.put(""+temp,temp);
},String.valueOf(i)).start();
}
// 讀取:可以插隊(duì)搶占資源以實(shí)現(xiàn)資源的最大化利用
for (int i = 1; i <= 5; i++) {
final int temp = i;
new Thread(()->{
myCache.get(temp+"");
},String.valueOf(i)).start();
}
}
}
class MyCache{
private volatile Map<String,Object> cache = new HashMap<>();
ReadWriteLock rwLock = new ReentrantReadWriteLock();
// 細(xì)粒化控制:寫 - 只希望同一時(shí)間只有一條線程寫入,寫入完成后再進(jìn)入下一位
public void put(String key,Object value){
rwLock.writeLock().lock();
try {
System.out.println(Thread.currentThread().getName()+":"+key+"開始寫入");
cache.put(key,value);
System.out.println(Thread.currentThread().getName()+":"+key+"寫入完成");
}catch (Exception e){
e.printStackTrace();
}finally {
rwLock.writeLock().unlock();
}
}
// 細(xì)粒化控制:讀 - 所有人都可以讀
public Object get(String key){
rwLock.readLock().lock();
Object o = null;
try {
System.out.println(Thread.currentThread().getName()+":"+key+"開始讀取");
o = cache.get(key);
System.out.println(Thread.currentThread().getName()+":"+key+"讀取完成");
}catch (Exception e){
e.printStackTrace();
}finally {
rwLock.readLock().unlock();
}
return o;
}
}
總結(jié)
以上是生活随笔為你收集整理的JUC并发编程学习笔记(八)读写锁的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: NEFU OJ Problem1356
- 下一篇: AtCoder Beginner Con