Volatile是轻量级的synchronized,它在多处理器开发中保证了共享变量的“可见性”java
Java语言规范第三版中对volatile的定义以下:编程
java编程语言容许线程访问共享变量,为了确保共享变量能被准确和一致的更新,线程应该确保经过排他锁单独得到这个变量。java语言提供了volatile,在某些状况下比锁更方便,若是一个字段被声明为volatile,java线程内存模型确保全部线程看到这个变量的值是一致的缓存
处理器为了提升处理速度,不直接和内存进行通信,而是先将系统内存的数据读到内存缓存后再进行操做,但操做完以后不知道什么时候会写到内存,若是对声明了volatile变量进行写操做,JVM就会向处理器发送一条Lock前缀的指令,将变量所在的缓存行写回到系统内存,可是就算写回到内存,若是其余处理器缓存的值仍是旧的,再执行计算操做就会有问题,因此在多处理器下,为了保证各个处理器的缓存是一致的,就会实现缓存一致性协议,每一个处理器经过嗅探在总线上传播的数据来检查本身缓存的值是否是过时了,当处理器发现本身缓存行对应的内存地址被修改,就会将当前处理器的缓存行设置成无效状态,当处理器要对这个数据进行修改操做的时候,会强制从新从系统内存里把数据读处处理器缓存里。编程语言