JUC编程06:读写锁、阻塞队列和同步队列

本文探讨了Java并发编程中的读写锁(ReadWriteLock)、阻塞队列(BlockingQueue)和同步队列(SynchronousQueue)。通过代码示例展示了读写锁如何确保写操作的互斥,防止数据不一致;阻塞队列在满和空时如何实现线程的阻塞与唤醒;同步队列的独特性质,即元素的入队和出队必须同步进行。
摘要由CSDN通过智能技术生成

一、读写锁ReadWriteLock

在这里插入图片描述

  • 代码演示
    ①、缓存类
public class MyCache {
    private volatile Map<String,Object> map=new HashMap<String, Object>();
    //创建一个读写锁
  private ReentrantReadWriteLock 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()+"写入成功");
        }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);
            map.get(key);
            System.out.println(Thread.currentThread().getName()+"成功获取");
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            readWriteLock.readLock().unlock();
        }
    }

}

②、测试类

public class ReadWriteLock {
    public static void main(String[] args) {
        final 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();
        }
    }
}
  • 没有读写锁的运行结果:
    在这里插入图片描述
    可以看到写入的时候多个线程一起的操作,没有等到前一个线程写入成功下一个线程就抢着进行写入了
  • 有读写锁的运行结果:
    在这里插入图片描述
    有读写锁的情况下,写操作的线程都是依次进行的,等到一个线程操作完成后再进行下一个下入操作

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

微笑AJJD

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值