java并发-CAS

java并发中锁可以解决线程安全的问题,但是缺点也是很明显的,当一个线程没有获取到锁时会被阻塞挂起,当锁释放后 ,又会重新调度,这种线程的上下文切换和重新调度带来了一定的性能开销。当然,java也提供了volatile关键字这种非阻塞的方法来解决共享变量在线程间的可见性问题。但是volatile虽然解决了可见性,并且也是非阻塞的,但是却不能保证原子操作。对于读-改-写(比如java的自增操作),使用volatile就会出问题。

针对于此,java提供了CAS锁机制--compare and swap。 CAS通过硬件保证了操作的原子性。

jdk中的rt.jar包中的Unsafe类提供了一系列的cas操作。

以Unsafe类中的public final native boolean compareAndSwapLong(Object obj, long valueOffset, long expect, long update)方法来举例说明cas的原理:四个参数分别是:操作对象,对象中的变量的偏移量,变量预期值,变量要更新的值。该方法功能为:如果对象obj中内存偏移量为valueOffset的变量值为expect,则将该值更新为update,并返回true,否则,返回false. 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值