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或者其他同步机制来避免因此可能出现的问题
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值