面试官:了解并发包中的CAS的作用及原理吗?

  

面试官:了解并发包中的CAS的作用及原理吗?

  前言

  JUC是java.util.concurrent包的简称,JUC有2大核心,CAS和AQS,CAS是

  java.util.concurrent.atomic包的基础

  

面试官:了解并发包中的CAS的作用及原理吗?

  由于这个代码是线程不安全的,所以最终结果有可能小于500,我们可以用synchronized保证操作的原子性和可见性

  

面试官:了解并发包中的CAS的作用及原理吗?

  synchronized属于悲观锁,它有一个明显的缺点,它不管数据存不存在竞争都加锁,随着并发量增加,且如果锁的时间比较长,其性能开销将会变得很大。有没有办法解决这个问题?答案是基于冲突检测的乐观锁。这种模式下,已经没有所谓的锁概念了,每个线程都直接先去执行操作,检测是否与其他线程存在共享数据竞争,如果没有则让此操作成功,如果存在买手游账号共享数据竞争则不断地重新执行操作,直到成功为止,重新尝试的过程叫自旋

  java.util.concurrent.atomic包就用到了CAS,如AtomicInteger可以用于Integer类型的原子性操作,可将上述代码改为如下,也是线程安全的

  

面试官:了解并发包中的CAS的作用及原理吗?

  CAS介绍

  CAS(Compare and Swap), 翻译成比较并交换。CAS有3个操作数,内存值V,旧的预期值A,要修改的新值B。当且仅当预期值A和内存值V相同时,将内存值V修改为B,否则什么都不做。

  

面试官:了解并发包中的CAS的作用及原理吗?

  AtomicInteger源码分析

面试官:了解并发包中的CAS的作用及原理吗?

  AtomicInteger的值保存在value中,通过volatile保证操作的可见性,通过一个静态代码块来保证,类被加载时valueOffset已经有值了

  Unsafe是一个不安全的类,提供了一些对底层的操作,我们是不能使用这个类的,valueOffset 是AtomicInteger对象value成员变量在内存中的偏移量

  我们看getAndIncrement这个方法(和value++一个效果),能保证AtomicInteger类加1操作的原子性

  

面试官:了解并发包中的CAS的作用及原理吗?

  compareAndSwapInt是native方法,就不再分析

  总结

  并发比较低的时候用CAS比较合适,并发比较高用synchronized比较合适

  CAS的缺点

  1.只能保证对一个变量的原子性操作

  2.长时间自旋会给CPU带来压力

  3.ABA问题

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值