volatile用于解决可见性和禁止重排序,不保证原子性;适用于原子读写场景,如状态标志(volatile boolean running)和DCL单例中防止半初始化。

volatile 主要用于解决多线程环境下的可见性和禁止指令重排序问题,但它不能保证原子性。所以它的适用场景很明确:变量的读写本身是原子操作(如基本类型 int、boolean、引用赋值),且不需要复合操作(比如 i++)的同步保障。
状态标志控制线程生命周期
最常见也最安全的用法是用 volatile 修饰一个布尔类型的“开关”变量,用来通知其他线程停止运行。
例如:
private volatile boolean running = true;while (running) { /* 执行任务 */ }
// 另一线程调用 stop():running = false;
这样能确保修改立即对所有线程可见,避免因缓存导致线程无法退出。
立即学习“Java免费学习笔记(深入)”;
双重检查锁定(DCL)中的实例引用
在单例模式中,volatile 可防止对象“半初始化”问题:
private static volatile Singleton instance;if (instance == null) {
synchronized (Singleton.class) {
if (instance == null) {
instance = new Singleton(); // volatile 确保构造完成才赋值,且禁止重排序
}
}











