Java--CAS问题汇总

本文深入探讨Java中的CAS机制,作为concurrent包的基础,CAS通过比较并交换的方式实现乐观锁,确保了多线程环境下变量更新的原子性。文章还解析了CAS底层实现原理,包括锁总线操作、禁止指令重排序及数据刷新机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于Java内的CAS,应该说它是整个c.u.t包的基石。

全称(compare and swqp),比较和交换,应该说看过源码的,尤其是最简单atomicInteger的,会发现它其实就是在自旋的基础上去更新某一个值,是一种乐观锁,它认为这个变量读大于写。

至于例子,我就引用原有的一篇博客,里面有测试例子。

CAS实践

今天要补充的是关于CAS底层的一些分析。

网上截取了一段关于CAS底层方法。


需要注意的是在执行cmpxchg方法时,这个方法就是执行change的方法,也就是写方法。当执行写方法时,加了一个LOCK信号。

关于LOCK信号是CAS需要关注的底层原理。


总结下:

1. 存在锁总线的操作,保证了写操作的原子性。

2.禁止了指令重排序。

3.会及时刷新数据到内存中。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值