CAS(无锁优化 自旋)

CAS : Compare and swap( V,Expected,NewValue)
cas有点像自旋锁,在初始阶段不会上锁,只有在具体操作时,才去判断

.CPU原语支持

if V == E
   V = NEW
 ELSE 
   try again or fail

//CPU原语保证在判断值相等和赋值之间是不会被打断的

原理: 哪期望值和原来的值比较,如果相同,就可以更值;否则try again or fail
AtomicInteger (使用CAS锁)

问题: ABA 问题?
原来的值,被改变了,然后就改回去了,如果判断

使用version
A 1.0
B 2.0
C 3.0
cas(version)

Unsafe类 – todo

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值