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

CAS的三大问题和解决方案

一、ABA问题的解决方案

变量第一次读取的值是1,后来其他线程改成了3,然后又被其他线程修改成了1,原来期望的值是第一个1才会设置新值,第二个1跟期望不符合,但是,可以设置新值。

解决方案:

(a)增加一个自定义的版本号变量,记录修改日志,每次修改一次,就加1 。当值相同时,还要比较版本号,如果版本号也一样,才能更新成新的值。
(b)采用原子引用类 AtomicStampedReference,通过控制变量值的版本号,来确保CAS的正确性,比较两个值引用是否一致,只有一致才会更新成新值。

二、无限循环问题(自旋)的解决方案

底层使用一个while循环来实现的,所以Atomic类设置值进入一个无限循环,只要失败了就不停的循环,再次疯狂的尝试。高并发场景下,多个线程频繁修改同一个值,则会导致大量线程执行compareAndSet的方法时,要循环 n 次才能更新成功,就是大量线程执行一个重复的空循环(自旋锁),造成系统的大量开销。

解决方案:

(a)采用 jdk 8 中的 LongAdder,分段CAS + 自动分段迁移。

三、多原子的变量问题的解决方案

一般的Atomic类,只能保证一个共享变量的原子性。

解决方案:

(a)采用 java 并发包的 AtomicReference,这个是封装自定义对象的,多个变量可放一个自定义对象中,然后它会检查该对象的引用是否是相同。如果多个线程,同时对一个对象变量的引用进行修改,AtomicReference 的 CAS 算法可解决并发冲突问题。

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

相关文章:

  • EDA和统计分析有什么区别
  • CentOS 7 修改DNS
  • PHP基础语法-Part2
  • 数据结构门槛-顺序表
  • 软件测试面试准备工作
  • Java面试八股之后Spring、spring mvc和spring boot的区别
  • linux对齐TOF和RGB摄像头画面
  • 配置linux客户端免密登录服务端linux主机的root用户
  • SpringMVC实现文件上传
  • 计算机实验室排课查询小程序的设计
  • 分享几种电商平台商品数据的批量自动抓取方式
  • mysql面试(五)
  • 微软全球蓝屏带来的思考及未来战争走向
  • 以FastGPT为例提升Rag知识库应用中的检索召回命中率
  • ffmpeg更改视频的帧率
  • 设计模式13-单件模式
  • 怎么给PDF文件加密码?关于PDF文件加密的四种方法推荐
  • GoFly快速开发框架基于Go语言和Vue3开发后台管理附件管理插件包
  • matlab实验:实验六MATLAB 数值计算与符号运算
  • 基于STM32设计的老人摔倒检测系统(4G+华为云IOT)(193)
  • PyTorch和TensorFlow概念及对比
  • github的Codespaces是什么
  • Unity UGUI 之 图集
  • rust日常提问
  • Vue3与Element-plus配合 直接修改表格中的一项数据——控制输入框的显示与隐藏
  • 设计模式--创建型
  • Vue3时间选择器datetimerange在数据库存开始时间和结束时间
  • 鼠标移入事件 mouseover
  • UE4 自动换行——按排序关键字1.2.3.
  • Object.entries()解析出来的数组顺序乱了,健是string类型