Java保证对声明为long和doubles的易失性进行原子读/写(即使在32位环境中也是如此),而C#则不能(编译错误)。为什么C#不支持这一点,而它是在字节码级别处理的呢?
发布于 2015-03-02 23:05:19
为什么C#不支持它?
如果您运行的是具有64位CLR版本的64位系统,则long and double reads and writes are guaranteed to be atomic
如果在64位操作系统上使用64位版本的CLR运行C#代码,则64位双精度型和长整型的读取和写入也可以保证是原子的
这是根据CLI specification,§I.12.6.6节:
一致性命令行界面应保证,当对一个位置的所有写访问都是相同大小时,对正确对齐的存储器位置的读写访问不大于本机字大小(本机int类型的大小)是原子的(参见§I.12.6.2)。原子写不能改变除写入的位以外的任何位。除非使用显式布局控制(参见Partition II (控制实例布局))来更改默认行为,否则不大于自然字长(本机int的大小)的数据元素应正确对齐。应将对象引用视为以原生字长存储。
https://stackoverflow.com/questions/28812899
复制相似问题