可重入锁介绍、使用

1、什么是可重入锁?

可重入锁,也叫做递归锁,指的是同一线程外层函数获得锁之后 ,内层递归函数仍然可以获取该锁的代码,但不受影响。

可重入锁使用示例

public class SynchronizedSample implements Runnable {
    public synchronized void funA() { // 执行funA方法,需要获取对象锁
        // synchronized属于可重入锁,进入funA方法后,拥有了对象锁,所以执行方法funB方法时不受影响。
        System.out.println(Thread.currentThread().getName() + " " + Thread.currentThread().getId());
        funB();
    }
    public synchronized void funB() { // 执行funB方法,需要获取对象锁
        System.out.println(Thread.currentThread().getName() + " " + Thread.currentThread().getId());
    }
    @Override
    public void run() {
        funA();
    }
    public static void main(String[] args) {
        SynchronizedSample ss = new SynchronizedSample();
        new Thread(ss).start();
        new Thread(ss).start();
        new Thread(ss).start();
    }
}
public class ReentrantLockSample implements Runnable {
    ReentrantLock lock = new ReentrantLock();
    public void funA() { // 执行funA方法,需要获取对象锁
        lock.lock(); // 第一次获取锁
        System.out.println(Thread.currentThread().getName() + " " + Thread.currentThread().getId());
        funB(); // 该方法会第二次获取锁
        lock.unlock();
    }
    public void funB() { // 执行funB方法,需要获取对象锁
        lock.lock();
        System.out.println(Thread.currentThread().getName() + " " + Thread.currentThread().getId());
        lock.unlock();
    }
    @Override
    public void run() {
        funA();
    }
    public static void main(String[] args) {
        ReentrantLockSample rs = new ReentrantLockSample();
        new Thread(rs).start();
        new Thread(rs).start();
        new Thread(rs).start();
    }
}

程序输出结果

Thread-1 14
Thread-1 14
Thread-2 15
Thread-2 15
Thread-0 13
Thread-0 13

2、可重入锁作用及使用场景?

  1. 可重入锁最大作用是避免死锁。
  2. 当一个线程执行一个带锁的代码块或方法,同时代码块或方法里也获取同一个锁。为了避免死锁,此时就可以用可重入锁。

3、在内置锁sychronized和ReentrantLock类之间进行选择

相同点

  1. 两种方式在加锁和内存上提供的语义相同。

不同点

  1. ReentrantLock提供了其他的功能,包括定时的锁等待、可中断的锁等待、公平与非公平锁。而sychronized没有这些功能。
  2. ReentrantLock的性能比sychronized要高一些。
  3. sychronized锁使用方式简单,代码表达直接紧凑,使用范围广,被许多开发人员所熟悉。
  4. sychronized在线程转储中能给出在哪些调用帧中获得了哪些锁,并能够检测和识别发生死锁的线程。而java6之后ReentrantLock提供了管理和调试的接口弥补了这一点。
  5. 未来的情况下,可能会提升sychronized而不是ReentrantLock的性能。因为sychronized是JVM的内置属性,优化可能性很大。

使用建议

在一些内置锁sychronized无法满足需求的情况下,ReentrantLock可作为高级工具使用。否则,应该优先考虑使用sychronized。

/**
 * 欢迎评论、留言、发表看法。谢谢!
 */

转载于:https://www.cnblogs.com/mengHeJiuQIan/p/11158012.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值