可重入锁

可重入锁即我调用加锁方法,该方法又调用了另一个加锁方法,相当于锁了两次(N次),但是不会出现死锁。
可重入锁:递归锁,外层函数获取锁之后,内层函数可以自动获取该锁,解决死锁问题
synchronized和reentrantLock是可重入锁

先说下sync:

必须是同一个线程,同一把锁才可以。
例子:
新建线程访问m1,m1打印后调用m2,两方法均锁定当前对象,并且均为同一线程,所以两方法可同时运行
在这里插入图片描述

——————————————————————————————————
其他例子1:如果不是同一个线程访问 m2阻塞
在这里插入图片描述
其他例子2:如加锁和未加锁同时运行,不会阻塞
在这里插入图片描述
其他例子3:锁的不是同一个对象,线程不会阻塞。
在这里插入图片描述

reentrantlock实现可重入锁

和sync一样,值得注意的是,sync是隐式锁,释放锁的过程无需我们设置,但reentrantlock是显式锁,必须手动解锁,否则会造成死锁!!!
例子1:同一线程调用同锁不同方法实现可重入锁
在这里插入图片描述
例子2:非同一线程会造成阻塞
在这里插入图片描述
例子3:如未释放锁,死锁
在这里插入图片描述

reentrantlock对synchronized的优化:
1.可以尝试申请锁
如果获取锁的时候是空闲的,那么线程访问,否则什么也不做
也可以指定时间,例多久之后我获取到锁,而后操作
在这里插入图片描述
2.lockInterruptibly()==》可以被打断的加锁
sync一旦wait,必须通过锁对象上的其他线程notify才可以
3.reentrantlock可以设置成公平锁,默认非公平锁

  static Lock lock = new ReentrantLock(true);

后期会对底层实现原理进行整理

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值