Java的long和double类型的赋值操作为什么不是原子性的?

在这里插入图片描述

  1. 对一个没有用volatile修饰的long或double类型的写操作会被拆分成两次写,每次写该类型的32-bit数据,这就导致了在多线程的场景下,可能一个线程看到了对这个64-bit数据类型写入的前32-bit数据,和被另一个线程的后32-bit的数据
  2. 使用volatile修饰后的long和double类型的读写操作是原子性的
  3. 对其引用类型(Long/Double)的读写操作总是原子的,尽管他们的实现可能被分为两次32-bit或者一个64-bit
  4. 不同JVM的实现对这个问题的处理方案不同,可能会将long/double分为两次32-bit写入,也可能直接写入64-bit,但是建议JVM的实现要避免将数据拆为两次写入,而编码者应该显示的使用volatile或者其他同步机制来避免因此可能出现的问题