volatile是轻量级的synchronized,它在多处理器开发中保证了共享变量的“可见性”。可见性指的是当一个线程修改一个共享变量时,另外一个线程能够读到这个修改的值。由于它不会引起线程上下文的切换和调度,因此恰当地使用volatile会比synchronized的使用和执行成本更低。
volatile的定义Java编程语言允许线程访问共享变量,为了确保共享变量能被准确和一致性地更新,线程应该确保通过排他锁单独获得这个变量。
volatile如何保证可见性?有volatile修饰的变量进行写 *** 作时会多出一行汇编代码,这个代码指的是有Lock前缀的指令。
有Lock前缀的指令 具体作用:
① 将当前处理器缓存行的数据写回到系统内存中;
② 这个写回内存的 *** 作会使在其它CPU里缓存了该内存地址的数据无效。
具体来讲,为了提高处理速度,处理器不直接和内存进行通信,而是先将系统内存中的数据读到内部缓存中后再进行 *** 作,但是 *** 作完不知道何时会写到内存。如果对声明了volatile的变量进行写 *** 作,JVM会向处理器发送一条Lock前缀的指令,将这个变量所在缓存行的数据写回到系统内存中。为了保证写回内存后,其它处理器缓存的值还是旧的,就会实现缓存一致性协议,每个处理器会查看在总线上传播的数据来检查自己缓存的值是不是修改了,当处理器发现自己缓存行对应的内存地址被修改,就会将当前处理器缓存行设置为无效状态,当处理器对这个数据进行修改时,重新从系统内存中把数据读到处理器缓存里。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)