1、volatile是轻量级的synchronized,它在多处理器开发中保证了共享变量的可见性。
2、为了提高处理器速度,处理器不直接和内存进行通信,而是先将系统内存的数据读到内部缓存(L1,L2或其他)后再进行操作,但操作完不知道何时会写到内存。
3、volatile保证可见性的原理是利用处理器的lock指令:
(1)将当前处理器缓存行的数据写回到系统内存。
(2)这个写回内存的操作会使在其他CPU里缓存了该内存地址的数据无效。
4、独占共享内存:处理器的LOCK#信号,可以锁住总线,导致其他CPU不能访问总线,不能访问总线就意外着不能访问系统内存。
5、缓存一致性协议:在多处理器下,为了保证各个处理器的缓存是一致的,每个处理器通过嗅探在总线上传播的数据来检查自己缓存的值是不是过期了,当处理器发现自己缓存行对应的内存地址被修改,就会将当前处理器的缓存行设置成无效状态,当处理器对这个数据进行修改操作的时候,会重新从系统内存中把数据读到处理器缓存里。