当前位置: 首页 > news >正文

悲观锁和乐观锁详细

悲观锁和乐观锁详细

悲观锁

​ 悲观锁就是悲观的思想,他认为数据每一次被访问的时候都会被上锁,所以每次获得锁的时候都会上锁,这样其他线程想要获取这个锁的时候就会被堵塞,要等待上一个线程锁的释放。也就是说这个线程只一次只给一个线程使用,其他线程会被堵塞。当上一个线程使用完其他线程就可以竞争到这个锁。

​ 在高并发的场景下,激烈的锁景长会造成线程堵塞,大佬的堵塞线程会导致线程的上下文切换,会增加系统性能的消耗,而且悲观锁还有可能存在死锁的问题,影响代码的运行。

​ 悲观锁的每次开销是固定的。

什么是乐观锁

​ 乐观锁每次都是假设的最好的情况,它认为资源每次被访问的时候不会被修改,线程可以不停的执行,无序加锁无序等待,只是提交修改数据的时候需要验证一下我们的医院是否被其他的县城修改了(下面CAS算法会详细介绍)。比如我们的AtomicInteger、LongAdder就是使用我们乐观锁的思想。

​ 在高并发中,乐观锁不会出现线程堵塞和思索的问题,性能会比悲观锁性能更好一点,但是如果突然频繁发生写占比非常多的业务情况,回频繁失败和重试,这就会造成我们CPU飙升,影响我们的应能。乐观锁的使用场景都是写比较少的地方。

​ 在我们乐观锁是使用了版本号机制和CAS算法实现的, 但是内部使用的CAS算法更多一点。

版本号控制器

​ 版本号就是在数据表种加一个数据版本号version字段,如果我们的数据修改成功我们的version会自加1。当线程A要更新数据的时候,会读取当前的版本号,在提交数据的时候会拿我们读到的版本号和我们表种的版本号是否一样,如果一样的话就会更新,然后version++,否则就重试更新操作直到更新成功。

CAS算法

​ CAS就是Compare And Swap(比较与交换),用户乐观锁当中,被广泛用到个大框架,CAS的思想很简单,就是用一个预期值和要更新的值进行比较,两者相等就会更新

​ CAS是一个原子操作,底层依赖一条CPu的原子指令。

原子操作就是一旦开始就不能被打断,直到操作完成

​ CAS(Compare And Swap)涉及到3哥操作数

​ **V:**需要更新的变量值

E: 预期的值

​ **N:**拟写入的新值(新的值)

当V的值等于E的时候,CAS会通过原子方式用N来更新V,如果不相等那么就说明其他线程更新了V,当前线程就会放弃更新。

乐观锁存在的问题

ABA问题

ABA的问题i就是我们乐观锁最常见的问题。如果一个变量V初次读取的时候是A,然后准备赋值的时候检查也是A,这个时候我们不能说明它没有被其他线程修改过,因为很可能这时候其他线程把这个值修改成了B,然后有被修改成A,这时候CAS就会判定他没有被修改。

ABA的解决思路是在变量前面追加一个时间戳,在JDK1.5以后的AtomicStampedReference类就是用来解决ABA问题的,其中的compareAndSet就是检测我们当前的引用是否等于预期的引用,如果标志相等就更新。

循环时间长开销大。

因为CAs经常会用到自选操作进行重试,如果不成功就会循环执行到成功为止,如果长时间不成功就会给我们的CPU带来很大的压力。

只能对一个共享变量进行原子操作

CAS支队单个贡献变量优先,当操作涉及多个共享变量的时候CAS就会无效,但是JDK1.5的时候开始,提供了AtomicReference类保证引用对象之间的原子性,我们也可以把多个变量放到一个对线里进行CAS操作,所以我们可以使用锁或者利用AtomicReference类把多个共享变量合并成一个共享变量进行操作。

http://www.lryc.cn/news/61322.html

相关文章:

  • 三谈ChatGPT(ChatGPT可以解决问题的90%)
  • Qt QSet 详解:从底层原理到高级用法
  • Mac Doxygen的使用
  • FPGA基础代码复用
  • Hbase简介
  • 科海思除COD树脂,大孔树脂,除COD专用树脂
  • Qt 多线程 QThread、QThreadPool使用场景
  • 如何一招搞定PCB阻焊过孔问题?
  • 【代码随想录】刷题Day2
  • Python机器学习、深度学习技术提升气象、海洋、水文领域实践应用
  • 计及调度经济性的光热电站储热容量配置方法【IEEE30节点】(Matlab代码实现)
  • “不要放过这个春天”解锁品牌春日宣传新玩法
  • 利用GPT2 预测 福彩3d预测
  • 类加载过程
  • 【C/C++】C++11 无序关联容器的诞生背景
  • h264编码原理
  • 网络工程师经常搞混的路由策略和策略路由,两者到底有啥区别?
  • 高精度气象模拟软件WRF实践技术
  • 总结827
  • 还在发愁项目去哪找?软件测试企业级Web自动化测试实战项目
  • 总结下Spring boot异步执行逻辑的几种方式
  • 【开发日志】2023.04 ZENO----Composite----CompNormalMap
  • 春秋云境:CVE-2022-28525 (文件上传漏洞)
  • 【软件测试二】开发模型和测试模型,BUG概念篇
  • 短视频app开发:如何实现视频直播功能
  • [架构之路-174]-《软考-系统分析师》-5-数据库系统-7-数据仓库技术与数据挖掘技术
  • 销售高品质 FKM EPDM NBR 硅胶 O 形密封圈
  • Linux环境变量:不可或缺的系统组成部分
  • FFmpeg命令行解析
  • 机器学习——为什么逻辑斯特回归(logistic regression)是线性模型