前段日子看了些原子操作的文章,发现上面都说原子操作并非数据同步。但是原子操作即被定义为不需要同步控制的操作,那为什么会出现数据的不同步呢?还有什么样的操作被称之为原子操作?带着这些问题我查阅了写Java书籍,在《Think in java》(第三版)中发现了答案。
首先,原子操作是不能分割的操作,因此他不需要同步控制,已达到的数据同步。在Java 中基本类型的赋值和返回值操作是原子操作(不包括long 型和double型),那么为什么网上的各种Java 例子有充分的反应出原子操作的确发生了数据不统一现象呢?
在《Think in java》(第三版)第490 页中做出了明确的解释。书的原文如下:。。。,原子操作也很容易访问到对象尚处于不稳定状态时的值。这句话我是这么理解的,原子操作是可以不需要同步控制,但他却可以访问正在使用的数据,而导致的数据不一致。
什么是正在访问的数据呢?其实就是其他线程正在使用这个数据,但是你却通过原子操作访问到了该值,因此引发的数据不一致现象。
这些都是我个人的理解,如有错误,希望大家能我一点指点。在这先谢谢大家了。:)
首先,原子操作是不能分割的操作,因此他不需要同步控制,已达到的数据同步。在Java 中基本类型的赋值和返回值操作是原子操作(不包括long 型和double型),那么为什么网上的各种Java 例子有充分的反应出原子操作的确发生了数据不统一现象呢?
在《Think in java》(第三版)第490 页中做出了明确的解释。书的原文如下:。。。,原子操作也很容易访问到对象尚处于不稳定状态时的值。这句话我是这么理解的,原子操作是可以不需要同步控制,但他却可以访问正在使用的数据,而导致的数据不一致。
什么是正在访问的数据呢?其实就是其他线程正在使用这个数据,但是你却通过原子操作访问到了该值,因此引发的数据不一致现象。
这些都是我个人的理解,如有错误,希望大家能我一点指点。在这先谢谢大家了。:)