/**
* 独占锁(写锁):一次只能被一个线程私有
* 共享锁(读锁):多个线程可以同时占有
*/
public class ReadWriteLockTest {
public static void main(String[] args) {
MyCacheLock myCache = new MyCacheLock();
//写入
for (int i = 0; i < 5; i++) {
final int temp = i;
new Thread(()->{
myCache.put(temp+"",temp+"");
},String.valueOf(i)).start();
}
//读取
for (int i = 0; i < 5; i++) {
final int temp = 1;
new Thread(()->{
myCache.get(temp+"");
},String.valueOf(i)).start();
}
}
}
class MyCacheLock{
private volatile Map<String, Object> map = new HashMap<String,Object>();
//读写锁
private ReadWriteLock readWriteLock = new ReentrantReadWriteLock();
//存,写入的时候,只希望同时只有一个线程写
public void put(String key, Object value){
readWriteLock.writeLock().lock();
try{
System.out.println(Thread.currentThread().getName()+"写入"+key);
map.put(key,value);
System.out.println(Thread.currentThread().getName()+"写入OK");
}catch(Exception e){
e.printStackTrace();
}finally {
readWriteLock.writeLock().unlock();
}
}
//取,读,所有人都可以读!
public void get(String key){
readWriteLock.readLock().lock();
try{
System.out.println(Thread.currentThread().getName()+"读取"+key);
Object o = map.get(key);
System.out.println(Thread.currentThread().getName()+"读取OK");
}catch (Exception e){
e.printStackTrace();
}finally {
readWriteLock.readLock().unlock();
}
}
}
读写锁ReadWriteLock
最新推荐文章于 2024-08-17 10:11:38 发布
该博客展示了如何使用Java的ReentrantReadWriteLock实现读写锁,以达到在多线程环境下对资源的独占写入和共享读取。通过创建线程模拟并发写入和读取操作,演示了读写锁如何保证数据的一致性和并发性能。
摘要由CSDN通过智能技术生成