java 9 揭秘_Java面试题(九) 揭秘Java大陆的神秘家族“锁”之一族(二) 可重入锁(递归锁)...

一. 可重入锁(递归锁)

1. 定义:

指的时同一线程外层函数获得锁之后,内层递归函数仍然能获取该锁的代码,

在同一个线程在外层方法获取锁的时候,在进入内层方法会自动获取锁,也就是说,

线程可以进入任何一个它已经拥有的锁所同步着的代码块。

简单来说,可重入锁就是你回家后开了一个大门锁,就可以进入厨房,厕所,客厅等等。

2. 可重入锁作用:最大的作用就是避免死锁

3. 使用synchronized实现可重入锁

class Phone {

//证明 synchronized实现可重入锁

public synchronized void sendSMS() throws Exception {

System.out.println(Thread.currentThread().getName()+ "\t invoked sendMS()");

sendEmail();

}

public synchronized void sendEmail() throws Exception {

System.out.println(Thread.currentThread().getName() + "\t ### invoked sendEmail()");

}

}

调用

public static void main(String[] args) throws Exception{

System.out.println("验证 synchronized 可重入锁。。。");

Phone phone = new Phone();

new Thread(() -> {

try {

phone.sendSMS();

} catch (Exception e) {

e.printStackTrace();

}

}, "t1").start();

new Thread(() -> {

try {

phone.sendSMS();

} catch (Exception e) {

e.printStackTrace();

}

}, "t2").start();

运行结果:

453d345e1f940d10221fc9a2b20b19cb.png

4. 使用ReentrantLock实现可重入锁

class Phone implements Runnable{

//证明 ReentrantLock实现可重入锁

Lock lock = new ReentrantLock();

@Override

public void run() {

get();

}

public void get() {

//加锁几次就要解锁几次,要不然就会卡死,出不去。

lock.lock();

lock.lock();

try {

System.out.println(Thread.currentThread().getName()+ "\t invoked get()");

set();

} catch (Exception e) {

e.printStackTrace();

} finally {

lock.unlock();

lock.unlock();

}

}

public void set() {

lock.lock();

try {

System.out.println(Thread.currentThread().getName()+ "\t invoked set()");

} catch (Exception e) {

e.printStackTrace();

} finally {

lock.unlock();

}

}

}

调用

public static void main(String[] args) throws Exception{

System.out.println("验证 ReentrantLock 可重入锁。。。");

Phone phone = new Phone();

Thread t3 = new Thread(phone, "t3");

Thread t4 = new Thread(phone, "t4");

t3.start();

t4.start();

}

运行结果:

34a393f9327ed93c31386b7f21f929e0.png

总结:使用synchronized和ReentrantLock都可以实现可重入锁。

标签:重入,面试题,Java,Thread,lock,void,Exception,new

来源: https://blog.csdn.net/w_x_A__l__l/article/details/106870216

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值