CAS机制

本文详细介绍了Java中的CAS(CompareAndSwap)机制,探讨其在多线程环境下的原子性保证,如何通过Unsafe类优化读写操作,并列举了CAS在j.u.c Atomic和并发数据结构中的典型应用场景。
摘要由CSDN通过智能技术生成
什么是CAS机制

CAS是Java中Unsafe类里面的一个方法,它的全称是CompareAndSwap,比较并交换的一个意思,它的主要功能是能够去保证在多线程的环境下对于共享变量修改的一个原子性。

1
比如这样一个列子,有一个成员变量叫state,它的默认值是0,其中定义了一个方法叫doSmething(),这个方法的逻辑是先判断state是否为0,如果为0就修改成1,这个逻辑在单线程的情况下,没有任何问题,但是在多线程的环境下,会存在原子性的问题,因为这是典型的Read - Write的一个操作,一般情况下呢,我们会在doSmething()这个方法,去加一个Synchronized的同步锁来解决这样一个原子性问题,但是加同步锁一定会带来性能上的损耗。
2

如何优化

所以对这一类的场景,可以使用CAS机制来进行优化。这个是优化之后的一个代码,在doSmething()这个方法中呢,我们调用了Unsafe类里面的compareAndSwapInt()方法来达到同样的目的,这个方法呢有四个参数,分别是当前对象实例,成员变量state在内存地址中一个偏移量,预期值0和期望更改之后的值1,CAS机制会比较state内存地址偏移量对应的值和传入的预期值0是否相等,如果相等直接修改内存地址中state的值等于1,否则返回false,表示返回失败,而这个过程它是一个原子的,不存在任何线程安全的问题,CompareAndSwap是一个native方法,实际上,它最终还是会面临同样的问题,先从内存地址中读取state值,然后再去比较,最后再去修改,这过程不管在什么层面去实现,都会存在原子性问题,所以在CompareAndSwap的底层实现里面呢,如果在多核的cpu环境下会增加一个lock指令来对缓存或者总线去加锁,从而是保证比较并替换这两个操作的原子性。

CAS应用场景

CAS主要是应用在并发场景里面,比较典型的使用场景

  1. 第一个是j.u.c里面Atomic的原子实现,比如说AtomicInteger和Atomiclong
  2. 第二个是实现多线程对共享资源的互斥性质,比如AQS,ConcurrentHashMap,以及ConcurrentLinkedQueue等
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

请叫我黄同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值