CAS分析

CAS(Compare And Swap)是Java并发编程中的一种原子操作,常用于AQS同步组件和Atomic原子类。它在多处理器环境中通过硬件级别的原子操作实现,确保一次读-改-写操作的原子性。CAS存在循环时间过长、只保证单个共享变量原子性及ABA问题等缺点。在Java的Atomic类中,Unsafe类是实现CAS操作的核心,通过内存偏移地址获取和更新数据。
摘要由CSDN通过智能技术生成

一:概述

        CAS,Compare And Swap,即比较并交换。在Java多并非的操作中,很多地方都用到了CAS操作,如AQS同步组件、Atomic原子类操作都是以CAS实现的,甚至concurrentHashMap在版本1.8中也调用了CAS+Synchronized。可以说CAS在JUC中举足轻重。

二:CAS分析

      在CAS中有三个参数:内存中存放的值V,旧的预期值A,和要更新的值B,当且仅当V == A 的时候,才会进行V = B操作,否则什么都不干。可以看下其伪代码

if(this.value == A){
     this.value = B;
     return false;
 }else{
     return false;
 }

在Atomic原子类操作都用到了CAS,看下下面AtomicInteger中使用CAS。

 private static final Unsafe unsafe = Unsafe.getUnsafe();
 private static final long valueOffset;

 static {
      try {
          valueOffset = unsafe.obj
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值