为实现Java内存模型,对非volatile的long或double值的一次写操作是被当做两次独立地写操作来处理的:每次写一半——32位。这会导致一种情况,一个线程看到一个写操作写入的前32位,另一个写操作写入的后32位。
对volatile的long和double值的读与写总是原子的。
对引用的读与写总是原子的,不管它们是用32位还是64位实现的。
一些实现可以方便地将64位long或double值上的一次写操作分成相邻的32位值的两次写操作。
为提高效率,这种行为是特定于实现的;java虚拟机实现可以自由选择原子的或分成两次写入long或double值。
Java虚拟机规范鼓励尽可能避免分开处理64位值,同时鼓励程序员将共享的64位值声明为volatile或正确地使用同步以避免并发问题。