Lock接口的三个实现类

一.ReentrantLock(可重入锁)

即可重入锁。
具体可看:https://mp.csdn.net/mdeditor/100807462#

例:

class Clerk {
    private int product = 0;//共享数据
    private Lock lock = new ReentrantLock();//创建锁对象
    private Condition condition = lock.newCondition();//获取condition实例
    public  void get() { //进货
        lock.lock();//上锁
        try {
            while (product >= 1) {
                System.out.println("产品已满");
                try {
                    condition.await();//满了就等待
                } catch (InterruptedException e) {
                }
            }
            System.out.println(Thread.currentThread().getName() + ":" + (++product));
            condition.signalAll();//没满就可以进货
        }finally {
            lock.unlock();//释放锁
        }
    }

    public  void sell() {//卖货
        lock.lock();//上锁
        try {
            while (product <= 0) {
                System.out.println("缺货");
                try {
                    condition.await();//缺货就等待
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            System.out.println(Thread.currentThread().getName() + ":" + (--product));
            condition.signalAll();//不缺货就可以卖
        }finally {
            lock.unlock();//释放锁
        }
    }
}

二.ReentrantReadWriteLock类中的静态内部类ReadLock(读-写锁)

与互斥锁定相比,读-写锁定允许对共享数据进行更高级别的并发访问。虽然一次只有一个线(writer 线程)可以修改共享数据,但在许多情况下,任何数量的线程可以同时读取共享数据(reader 线程)。从理论上讲,与互斥锁定相比,使用读-写锁定所允许的并发性增强将带来更大的性能提高。
写写/读写需要互斥,读读不需要互斥。

三.ReentrantReadWriteLock类中的静态内部类WriteLock(读-写锁)

与互斥锁定相比,读-写锁定允许对共享数据进行更高级别的并发访问。虽然一次只有一个线(writer 线程)可以修改共享数据,但在许多情况下,任何数量的线程可以同时读取共享数据(reader 线程)。从理论上讲,与互斥锁定相比,使用读-写锁定所允许的并发性增强将带来更大的性能提高。
写写/读写需要互斥,读读不需要互斥。

例:

public class TestReadWriterLock {
    public static void main(String[] args){
           ReadWriterLockDemo rw = new ReadWriterLockDemo();
           new Thread(new Runnable() {//一个线程写
               @Override
               public void run() {
                   rw.set((int)Math.random()*101);
               }
           },"write:").start();
           for (int i = 0;i<100;i++){//100个线程读
               Runnable runnable = () -> rw.get();
               Thread thread = new Thread(runnable);
               thread.start();
           }
    }
}

class ReadWriterLockDemo{
    private int number = 0;
    private ReadWriteLock readWriteLock = new ReentrantReadWriteLock();
    //读(可以多个线程同时操作)
    public void get(){
        readWriteLock.readLock().lock();//上锁
        try {
            System.out.println(Thread.currentThread().getName()+":"+number);
        }finally {
            readWriteLock.readLock().unlock();//释放锁
        }
    }
    //写(一次只能有一个线程操作)
    public void set(int number){
        readWriteLock.writeLock().lock();
        try {
            System.out.println(Thread.currentThread().getName());
            this.number = number;
        }finally {
            readWriteLock.writeLock().unlock();
        }
    }
}

参考:https://blog.csdn.net/m0_38110132/article/details/74571805
           https://www.jianshu.com/p/1f19835e05c0

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java中的Lock接口提供了比synchronized关键字更加灵活和强大的线程同步机制。下面是Lock接口的常用方法: 1. lock():获取锁,如果锁已经被其他线程占用,则当前线程会被阻塞。 2. tryLock():尝试获取锁,如果锁没有被其他线程占用,则获取锁成功并返回true;否则返回false,不会阻塞当前线程。 3. tryLock(long time, TimeUnit unit):在指定时间内尝试获取锁,如果在指定时间内获取到锁,则返回true;否则返回false,不会阻塞当前线程。 4. unlock():释放锁,如果当前线程持有锁,则释放锁;否则会抛出IllegalMonitorStateException异常。 Lock接口实现包括ReentrantLock、ReentrantReadWriteLock.ReadLock和ReentrantReadWriteLock.WriteLock等。其中ReentrantLock是最基本的实现,而ReentrantReadWriteLock.ReadLock和ReentrantReadWriteLock.WriteLock是对读写锁的支持。 使用Lock接口进行线程同步时,需要注意以下几点: 1. 获取锁后必须在finally块中释放锁,否则可能导致死锁。 2. 不要使用Lock接口代替synchronized关键字进行简单的线程同步,因为Lock接口需要手动释放锁,容易出错。 3. 在使用ReentrantLock实现线程同步时,如果获取锁的线程出现异常而没有释放锁,则可能会导致其他线程一直阻塞,从而产生死锁。为了避免这种情况,建议使用try-finally块释放锁,或者使用Lock接口提供的unlock()方法释放锁。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值