ReentrantLock是一个悲观锁

ReentrantLock底层是由AQS实现的,ReentrantLock机制可以说是实打实的悲观锁。

来自:https://blog.csdn.net/qq_35688140/article/details/101223701
众所周知,ReentrantLock是一个悲观锁,但是查看源码,发现底层实现使用的是compareAndSet相关方法实现的,
于是产生疑问:为什么ReentrantLock使用的和CAS一样的compareAndSet相关的方法实现的,
CAS确实乐观锁,ReentrantLock却是悲观锁?

猜想一:仔细看代码发现ReentrantLock使用了setExclusiveOwnerThread方法,
这个方法是将某一个线程设置为独占线程。就是我们常说的互斥锁。
该线程占用该方法以后就无法被其他线程占有,也就是线程的互斥。
所以这不符合乐观锁的定义:“认为自己在使用数据时不会有别的线程修改数据”。

评论区:
ReentrantLock用的AQS,AQS用的cas判断线程是否获取到锁。
而不是ReentrantLock用的cas判断共享值有没有被改变。我是这么理解的

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Java中,可以使用以下几种方式创建悲观锁: 1. 使用synchronized关键字:synchronized关键字是Java中内置的实现悲观锁的机制之一。通过在方法或代码块前添加synchronized关键字,可以使得多个线程在执行该方法或代码块时串行化。 ```java public synchronized void synchronizedMethod() { // 同步的方法体 } ``` ```java public void synchronizedBlock() { synchronized (this) { // 同步的代码块 } } ``` 2. 使用ReentrantLock类:ReentrantLock是Java提供的一种可重入锁机制,它实现了Lock接口,可以实现更加灵活的悲观锁控制。使用ReentrantLock可以通过lock()方法获取锁并在使用完后调用unlock()方法释放锁。 ```java private Lock lock = new ReentrantLock(); public void lockMethod() { lock.lock(); try { // 锁定的代码块 } finally { lock.unlock(); } } ``` 3. 使用ReadWriteLock类:ReadWriteLock是Java提供的一种读写锁机制,它允许多个线程同时读取共享资源,但只允许一个线程进行写操作。使用ReadWriteLock可以实现更高效的并发读取操作。 ```java private ReadWriteLock readWriteLock = new ReentrantReadWriteLock(); public void readMethod() { readWriteLock.readLock().lock(); try { // 读取共享资源的代码块 } finally { readWriteLock.readLock().unlock(); } } public void writeMethod() { readWriteLock.writeLock().lock(); try { // 写操作的代码块 } finally { readWriteLock.writeLock().unlock(); } } ``` 这些是Java中实现悲观锁的常见方式,具体的选择可以根据项目需求和线程安全性要求来决定。需要注意的是,在使用悲观锁时,要注意处理好锁的获取和释放,避免死锁和资源竞争的问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值