Java多线程volatile关键字

JVM中,分为JVM Client模式,JVM Server模式。两者区别并不大,但serve启动模式启动较慢,但一旦运行起来后,在hash和method call方面的效率,比Client模式效率高数十倍。

线程在读取数据时,首先从主内存中读取数据,保存在本地工作内存中,然后对数据进行修改,修改完毕后,写入本地工作内存中,再从工作内存写入主内存。示例图如下:

JVM如果以Server模式启动时,为了线程的效率,线程在第一次读取数据后,将数据保存在工作内存中,之后读取数据时,均从工作内存中读取。但如果主内存修改了数据,则会导致工作内存的数据与主内存数据不一致。导致逻辑错误。

 

volatile关键字只可以修饰变量。当用volatile对某一个变量进行修饰后,每次读取变量均强制要求从主内存中读取,这样可以保证变量的一致性。保证数据的可见性,但并不能保证数据的原子性。

 

原文地址:https://www.cnblogs.com/CloudStrife/p/7151333.html