您的位置:首页 > 其它

volatile 原理

2018-03-22 09:41 225 查看
定义:Java 允许线程访问共享变量,为了确保共享变量能被准确和一致地更新,线程应该确保通过排他锁单独获得这个变量。

volatile 如何确保共享变量的可见性?

有 volatile 修饰的共享变量进行写操作时,它的汇编指令中会有 lock 字样,称为 Lock 前缀。Lock 前缀的指令在多核处理器下会引发两件事情:

1)将当前处理器缓存行的数据写回到系统内存

2)这个写回内存的操作会使其他 CPU 里缓存了该内存地址的数据无效

0x01a3de1d: movb $0×0,0×1104800(%esi);0x01a3de24: lock addl $0×0,(%esp);


解释:如果对声明了 volatile 的变量进行写操作时,JVM 会向处理器发送一条 Lock 前缀的指令,将这个变量所在缓存行的数据写回到系统内存。但是,其他处理器的缓存行内的数据仍然是旧数据。因此为了保证各个处理器的缓存是一致的,就要采用缓存一致性协议,即每个处理器通过嗅探在总线上传播的数据来检查自己缓存的值是不是过期了,当处理器发现自己缓存行对应的内存地址被修改了,就会将当前处理器的缓存行设置成无效状态,当处理器对这个数据进行修改操作时,会重新从系统内存中读取数据到缓存行中。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  volatile原理