可见性: 一个县城对共享变量的修改,另一个线程能够立刻看到。
volatile的意义时禁用CPU缓存
public class VolatileExample { int x = 0; volatile boolean v = false; public void writer(){ x = 42; v = true; } public void reader(){ if (v){ System.out.println(x); } }
假设线程A执行writer()方法,按照 volatile语义,会把变量 “v=true” 写入内存;假 设线程B执行reader()方法,同样按照 volatile 语义,线程B会从内存中读取变量v,如果线程B看到 “v == true” 时,那么线程B看到的变量x是多少呢?
1.5以前的版本会出现x=0的情况因为变量x可能被CPU缓存而导致 可见性问题。这个问题在1.5版本已经被圆满解决了。x=42,为什么呢?
如果线程B读到了“v=true”,那么线程A设置的“x=42”对线程B是可见的。也就是说,线程B能看到 “x == 42” ,有没有一种恍然大悟的感觉?这就是1.5版本对volatile语义的增强,这个增强意义重大,1.5版本 的并发工具包(java.util.concurrent)就是靠volatile语义来搞定可见性的。