🛸~~ 🚁🚁🚁🛩️🛩️�|

n1ce2cv

园龄:5年2个月粉丝:4关注:1

ReadWriteLock读写锁

ReadWriteLock读写锁

  • ReadWriteLock只允许一个线程修改,但是get()方法只读,不修改数据,实际上允许多个线程同时调用,使用ReadWriteLock可以解决这个问题

  • 适合读多写少的场景

  • 源码

public interface ReadWriteLock {
Lock readLock();
Lock writeLock();
}
  • 实现类:ReentrantReadWriteLock
  • 读锁(共享锁),写锁(独占锁)
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;
class MyReadWriteLock {
public static void main(String[] args) {
MyCache myCache = new MyCache();
for (int i = 0; i < 6; i++) {
final int temp = i;
new Thread(() -> {
// lambda无法访问到外部的变量
myCache.put(temp + "", "value:" + temp);
}, String.valueOf(i)).start();
}
for (int i = 0; i < 6; i++) {
final int temp = i;
new Thread(() -> {
myCache.get(temp + "");
}, String.valueOf(i)).start();
}
}
}
class MyCache {
private final Map<String, Object> map = new HashMap<>();
// 读写锁
private final ReadWriteLock lock = new ReentrantReadWriteLock();
// 只有一个可以写
public void put(String key, Object value) {
lock.writeLock().lock();
try {
System.out.println(Thread.currentThread().getName() + "写入" + value);
map.put(key, value);
System.out.println(Thread.currentThread().getName() + "写完毕");
} catch (Exception e) {
e.printStackTrace();
} finally {
lock.writeLock().unlock();
}
}
// 可以多个同时读
public void get(String key) {
lock.readLock().lock();
try {
System.out.println(Thread.currentThread().getName() + "读取" + map.get(key));
System.out.println(Thread.currentThread().getName() + "读完毕");
} catch (Exception e) {
e.printStackTrace();
} finally {
lock.readLock().unlock();
}
}
}

本文作者:n1ce2cv

本文链接:https://www.cnblogs.com/sprinining/p/15485404.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   n1ce2cv  阅读(130)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起