乐观锁及其实现原理,synchronized和ReentrantLock的区别

乐观锁是一种在读取数据时不加锁,但在更新时检查数据是否被其他线程修改的并发控制策略。通常通过版本号或CAS(Compare and Swap)操作实现。版本号方式通过在数据表中增加一个version字段,更新时比较并更新version值来避免冲突。而CAS操作则在内存中比较并交换值,确保数据一致性。相比于传统的synchronized,ReentrantLock提供了更高的灵活性,如可中断的等待、公平锁和多个条件变量等特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

乐观锁及其实现原理

乐观锁总是认为不会产生并发问题,每次去取数据的时候总认为不会有其他线程对数据进行修改,因此不会上锁,但是在更新时会判断其他线程在这之前有没有对数据进行修改,一般会使用版本机号或CAS操作实现。
version方式:一般是在数据表中加上一个数据版本号version字段,表示数据被修改的次数,当数据被修改时,version值会加一。当线程A要更新数据时,version值会加一。在提交更新时若刚才读到的version值为当前数据库中的version值相等时才更新,否则重试更新操作直到成功。
CAS操作方式:即compare and swap 或compare and set ,涉及到三个操作数,数据所在的内存值,新值。当需要更新时,判断当前内存值与之前取到的值是否相等。若相等则将新值写回,若不相等则重试,一般情况下是一个自旋操作,即不断的重试。
synchronized和ReentrantLock的区别

两者都是同步阻塞锁
功能区别: 1.Synchronized原生语法层面的互斥 JVM。
ReentTrantLock(1.5后 API 层互斥锁)。
2.便利性:Synchronized 方便简洁,由编译器去保证锁的加锁和释放。
ReentrantLock :手工声明未加锁和释放锁。
3.锁的细粒度和灵活度:ReenTrantLock > Synchronized
性能区别:
在Synchronized 优化前 性能 < ReentrantLock
高级功能:1.等待可中断, Lock.lockInterruptlbly();
2.公平锁 3.锁绑定多个条件。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值