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

详解CAS

一、CAS是什么?

CAS是Java中Unsafe类里面的一个方法,是Compare and Swap的缩写,中文翻译成比较并交换主要功能是能够去保证在多线程的环境下对于共享变量修改的一个原子性,实现并发算法时常用到的一种技术。它包含三个操作数——内存位置、预期值及更新值

CAS是JDK提供的非阻塞原子性操作,它通过硬件保证了比较-更新的原子性

执行CAS操作的时候,将内存位置的值与预期原值比较

  • 如果相匹配,那么处理器会自动将该位置值更新为新值;
  • 如果不匹配,处理器不做任何操作,多个线程同时执行CAS操作只有一个会成功。

 1.1 CAS底层原理?如果知道,谈谈你对Unsafe的理解

1、 变量state用volatile修饰,保证了多线程之间的内存可见性。

2、Unsafe的特点:

  1. 不受jvm管理,也就意味着无法被GC,需要我们手动GC,稍有不慎就会出现内存泄漏。
  2. Unsafe的不少方法中必须提供原始地址(内存地址)和被替换对象的地址,偏移量要自己计算,一旦出现问题就是JVM崩溃级别的异常,会导致整个JVM实例崩溃,表现为应用程序直接crash掉。
  3. 直接操作内存,也意味着其速度更快,在高并发的条件之下能够很好地提高效率。

3、变量stateOffset,表示该变量值在内存中的偏移地址,因为Unsafe就是根据内存偏移地址获取数据的。

1.2 CAS缺点

  • 循环时间长开销很大
  • 引出来ABA问题(举例:张三账户本来有1000块,今天该发工资3000块了,财务打款3000,账户此时4000,然而张三老婆知道张三今天该发工资了,急用取出3000,等张三查余额的时候,发现是1000,以为没发工资,所以这就是ABA问题)

二、自旋锁,借鉴CAS思想

自旋锁:是指当一个线程在获取锁的时候,如果锁已经被其它线程获取,那么该线程将循环等待,然后不断的判断锁是否能够被成功获取,直到获取到锁才会退出循环。

自旋锁的实现基础是CAS算法机制。CAS自旋锁属于乐观锁,乐观地认为程序中的并发情况不那么严重,所以让线程不断去尝试更新。

 

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

相关文章:

  • 《环境感知方案:探索未来智能世界的关键技术》
  • Android 编译时出现Android resource linking failed.without required default value.
  • golang ws升级为wss
  • FFMPEG录屏(17)--- 使用 DwmRegisterThumbnail 捕获指定窗口图像数据
  • 点亮一个LED(51)
  • Flink窗口分配器WindowAssigner
  • 【Tinymce】富文本编辑器在vue项目中的使用;引入付费格式刷,上传视频、图片
  • Java实现简单的5阶m序列密钥生成
  • 013_django基于大数据的高血压人群分析系统2024_dcb7986h_055
  • OpenCV高级图形用户界面(21)暂停程序执行并等待用户按键输入函数waitKey()的使用
  • 其他css的用途
  • json路径 [‘a‘].b.c[0].d[‘1‘].f,具体代表什么意思
  • 等保测评:如何进行有效的安全合规性审查
  • FFmpeg 4.3 音视频-多路H265监控录放C++开发二 : 18.04ubuntu安装,linux 下build ffmpeg 4.3 源码 并测试
  • 将两张图片的不同标记出来
  • HarmonyOS开发(State模型)
  • 在 WPF 中使用 OpenTK:从入门到进阶
  • 【最新华为OD机试E卷-支持在线评测】水仙花数(100分)多语言题解-(Python/C/JavaScript/Java/Cpp)
  • C# WinForm 用名字name字符串查找子控件
  • Ubuntu下安装并初始化Git同时添加SSH密钥
  • 好用的AI工具:探索智能生活的无限可能
  • -bash: conda: command not found
  • STM32-CubeIDE用串口通讯
  • FloodFill 算法(DFS)
  • 计算机通信与网络实验笔记
  • 闲聊【干龙头】的重要性
  • Ubuntu22.04安装RTX3080
  • 嵌入式学习-IO进程-Day04
  • RAII - 安卓中的智能指针
  • linux--库指令