JUC并发编程学习笔记(八)读写锁

读写锁

ReadWriteLock

ReadWriteLock只存在一个实现类那就是ReentrantReadWriteLock,他可以对锁实现更加细粒化的控制

读的时候可以有多个阅读器线程同时参与,写的时候只希望写入线程是独占的

Demo:

java 复制代码
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 {
    /*
    * 读读 - 可以共存 (共享锁)
    * 读写 - 不能共存 (独占锁)
    * 写写 - 不能共存 (独占锁)
    * */

    public static void main(String[] args) {



        MyCache myCache = new MyCache();
//        写入:要求在写入时不能存在插队的情况,以防止写入时资源被抢占
        for (int i = 1; i <= 5; i++) {
            final int temp = i;
            new Thread(()->{
                myCache.put(""+temp,temp);
            },String.valueOf(i)).start();
        }
//        读取:可以插队抢占资源以实现资源的最大化利用
        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();
//    细粒化控制:写 - 只希望同一时间只有一条线程写入,写入完成后再进入下一位
    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();

        }

    }
//    细粒化控制:读 - 所有人都可以读
    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;
    }
}
相关推荐
巨大八爪鱼3 分钟前
XP系统下用mod_jk 1.2.40整合apache2.2.16和tomcat 6.0.29,让apache可以同时访问php和jsp页面
java·tomcat·apache·mod_jk
码上一元2 小时前
SpringBoot自动装配原理解析
java·spring boot·后端
计算机-秋大田2 小时前
基于微信小程序的养老院管理系统的设计与实现,LW+源码+讲解
java·spring boot·微信小程序·小程序·vue
魔道不误砍柴功4 小时前
简单叙述 Spring Boot 启动过程
java·数据库·spring boot
失落的香蕉4 小时前
C语言串讲-2之指针和结构体
java·c语言·开发语言
枫叶_v4 小时前
【SpringBoot】22 Txt、Csv文件的读取和写入
java·spring boot·后端
wclass-zhengge4 小时前
SpringCloud篇(配置中心 - Nacos)
java·spring·spring cloud
路在脚下@4 小时前
Springboot 的Servlet Web 应用、响应式 Web 应用(Reactive)以及非 Web 应用(None)的特点和适用场景
java·spring boot·servlet
黑马师兄4 小时前
SpringBoot
java·spring
数据小小爬虫4 小时前
如何用Java爬虫“偷窥”淘宝商品类目API的返回值
java·爬虫·php