读写锁

A.什么是读写锁?
读操作共享资源,写操作独占资源

B.手写一个读写锁

import java.util.HashMap;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantReadWriteLock;

class cache {
    HashMap<String, String> map = new HashMap<>();
    ReentrantReadWriteLock rwlock = new ReentrantReadWriteLock();//读写锁

    //写方法
    public void put(String key, String value) throws InterruptedException {
        rwlock.writeLock().lock();
        try{
            System.out.println(Thread.currentThread().getName() + ":准备写入值");
            //为了验证其他线程并不会在某个线程写操作时获得锁
            Thread.sleep(300);
            map.put(key, value);
            System.out.println(Thread.currentThread().getName() + ":写操作完成");
        }finally {
            rwlock.writeLock().unlock();
        }
    }

    //读方法
    public void get(String key)
    {
        rwlock.readLock().lock();
        try{
            System.out.println(Thread.currentThread().getName()+":开始读");
            Thread.sleep(300);
            String res=map.get(key);
            System.out.println(Thread.currentThread().getName()+":结束读,结果是"+res);
        }catch(Exception e)
        {
            e.printStackTrace();
        }
        finally{
            rwlock.readLock().unlock();
        }
    }
}
public class readWriteLock {

    /*
        结果:
        3:准备写入值
        3:写操作完成
        0:准备写入值
        0:写操作完成
        4:准备写入值
        4:写操作完成
        1:准备写入值
        1:写操作完成
        2:准备写入值
        2:写操作完成
        0:开始读
        1:开始读
        2:开始读
        4:开始读
        3:开始读
        2:结束读,结果是2
        4:结束读,结果是4
        1:结束读,结果是1
        0:结束读,结果是0
        3:结束读,结果是3

    */

    public static void main(String[] args) throws InterruptedException {
        cache resource=new cache();
        //写锁5线程
        for(int i=0;i<5;i++) {
            final int value=i;
            new Thread(()->{
                try {
                    resource.put(String.valueOf(value),String.valueOf(value));
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            },String.valueOf(i)).start();
        }

        //让所有的写操作完成
        Thread.sleep(3000);

        //读锁5线程
        for(int i=0;i<5;i++)
        {
            final int value=i;
            new Thread(()->{
                resource.get(String.valueOf(value));
            },String.valueOf(i)).start();
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redisson的读写锁是一种特殊的锁机制,它允许多个线程同时占有读模式的锁,但一次只能有一个线程占有写模式的锁。当锁处于写模式时,所有试图对该锁加锁的线程都会被阻塞,直到锁被解锁。当锁处于读模式时,所有试图以读模式对其加锁的线程都可以获得访问权,但如果线程希望以写模式对此锁进行加锁,它必须等待所有的线程释放锁。通常情况下,当锁处于读模式锁定状态时,如果有其他线程试图以写模式加锁,读写锁通常会阻塞随后的读模式锁请求,以避免读模式锁长期占用,而等待的写模式锁请求长期阻塞。读写锁适用于对数据结构的读次数远远多于写次数的情况,因为读模式锁定时可以共享,而写模式锁定时是独占的。[3] 在Redisson中,可以通过以下方式使用读写锁: 1. 获取RedissonClient对象。 2. 使用RedissonClient对象的getReadWriteLock方法获取读写锁对象。 3. 使用读写锁对象的readLock方法获取读锁对象,或使用writeLock方法获取写锁对象。 4. 在需要加锁的代码块中,使用读锁对象的lock方法进行加锁,使用写锁对象的lock方法进行加锁。 5. 在加锁的代码块执行完毕后,使用读锁对象的unlock方法进行解锁,使用写锁对象的unlock方法进行解锁。 例如,在验证读锁的请求中,可以使用RedissonClient对象的getReadWriteLock方法获取读写锁对象,然后使用读锁对象的lock方法进行加锁,读取数据后再使用unlock方法进行解锁。在验证写锁的请求中,可以使用相同的方式获取读写锁对象,然后使用写锁对象的lock方法进行加锁,写入数据后再使用unlock方法进行解锁。[2] 总之,Redisson的读写锁是一种灵活且高效的锁机制,可以在多线程环境下实现对共享资源的安全访问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值