volatile关键字是Java提供的一种轻量级的同步机制,它解决的问题直接来源于Java内存模型(JMM)为了性能优化而带来的可见性和有序性问题。它的作用可以精准地概括为两点:保证变量的内存可见性和禁止指令重排序。”
第一部分:可见性 - 打破线程间的“内存隔阂”
1. 问题来源:JMM与工作内存
在JMM中,每个线程都有自己的工作内存(可以理解为CPU高速缓存、寄存器的抽象),它保存了该线程使用到的变量的主内存副本。线程对所有变量的操作都必须在工作内存中进行,不能直接读写主内存数据。
-
普通变量的读写流程:
-
读取:线程从主内存拷贝变量到工作内存,之后的操作都基于这个副本。
-
修改:线程在工作内存中修改副本,然后在某个不确定的时间点才将修改后的值刷新回主内存。
-
这就导致了一个严重问题:一个线程修改了普通变量的值,但其他线程可能无法立即看到这个更新。
2. volatile的解决方案
当一个变量被声明为volatile后:
-
写操作:当写一个
volatile变量时,JMM会立即将该线程工作内存中的新值强制刷新到主内存中。 -
读操作:当读一个
volatile变量时,JMM会

最低0.47元/天 解锁文章
795

被折叠的 条评论
为什么被折叠?



