关键字 volatile 是 Java 提供的最轻量级的同步机制, Java 内存模型对 volatile 专门定义了一些特殊的访问规则。下面我们就看它的规则:
当一个变量被 volatile 修饰后,它将具备以下两种特性。
1.线程可见性:当一个线程修改了被 volatile 修饰的变量后,无论是否加锁,其他线程都可以立即看到最新的修改,而普通变量做不到这点。
2.禁止指令重排序优化,普通的变量仅仅保证在该方法的执行过程中所有依赖赋值结果的地方能获取正确的结果,而不能保证变量赋值操作的顺序和程序代码的执行顺序一致。(数据重排请参加: http://www.infoq.com/cn/articles/java-memory-model-2 )
一些人认为使用 volatile 可以替代传统锁,提升并发性能,这个认识是错误的。 Volatile 仅仅解决了可见性的问题,但是他并不能保证互斥性,也就是说多线程并发修改某个变量时,依旧会产生多线程问题。因此,不能靠 volatile 来完全替代传统的锁。 Volatile 最适合使用的是一个线程写、其他线程读的场合,如果有多个线程并发写操作,仍然需要使用锁或者线程安全的容器或者院子变量来替代。对一个 volatile 变量的读,总是能看到(任意线程)对这个 volatile 变量最后的写入。