原子操作(二)
一、什么是原子操作
不可被中断的一个或一系列操作
二、Java中如何实现原子操作
通过锁和循环CAS(自旋)的方式来实现
三、什么是CAS(Compare And Swap)
比较并且交换的一个原子操作,由处理器提供的CMPXCHG指令保证
//AtomicInteger的计数是典型的CAS public final int incrementAndGet() { for (;;) { int current = get(); int next = current + 1; if (compareAndSet(current, next)) return next; } } //Unsafe调用操作系统的指令 public final boolean compareAndSet(int expect, int update) { return unsafe.compareAndSwapInt(this, valueOffset, expect, update); }
四、CAS操作的三大问题
1、ABA问题
一个值原来是A,变成了B,又变成了A,CAS检测时以为值没有变化,其实已经变化。
可通过增加版本号来解决ABA问题
2、循环时间长cpu开销大
3、只能保证一个共享变了的原子操作
相关推荐
AlexZhao 2020-06-04
gongruitao 2019-12-27
lvxingzhe 2019-11-04
xienue 2019-10-29
wsxsxz 2019-10-21
书山有路勤为径 2019-07-01
Jhonse技术 2011-01-07
山水沐光 2019-05-09
Broadview 2010-02-19
朝气蓬勃 2019-06-12
sgafdsg 2011-04-18
hello小工 2017-10-09
VacantYang 2018-04-05
wxysummer 2016-10-24
teamojiao 2015-11-12
NSSpeak信息安全 2017-12-22
daoge00 2019-04-09
编程10000问 2019-03-27
BitTigerio 2018-05-31
编程语言与高级语言虚拟机杂谈仮 2018-05-27
数据分析侠 2018-04-24