volatile关键字疑惑,请大神帮忙解释下

学习jvm时遇到以下代码说是在stop变量上不加volatile,代码就会一直执行,实践中发现加不加都不会一直执行,我理解为加的话,线程的工作内存数据会立马拷贝到共享内存中去,所以程序不会一直执行,不加的话,线程工作内存数据不会立马拷贝到共享内存中去,经过一段时间,拷贝到共享内存之中,程序就不会一直执行了,奇怪的是加上 Thread.sleep(2000);之后,在stop变量上不加volatile,程序就会一直执行,加的话,程序会停止执行,想不明白这是为什么,大神可以解释下吗?

public class StopExample
{
//volatile 加关键字实现线程共享
boolean stop = false;
public static void main(String[] args) throws Exception
{

StopExample stopExample = new StopExample();
new Thread(() ->
{
  stopExample.doWork();
}).start();

//???加上之后不用volatile 就一直停止不了
Thread.sleep(2000);
new Thread(() ->
{
  stopExample.shutDown();
}).start();

}

public void shutDown()
{
stop = true;
}

public void doWork()
{
while (!stop)
{

}
System.out.println("shut down success");

}
}

1个回答

你启动了两个线程,Boole stop变量在第二条线程中改变为false,根据Java内存分布原理,每个线程拥有独立的内存空间,所以你改变的stop值对第一条线程不可见,所以第一条线程无法停止。volatile关键字的作用便是使得变量全局可见,所以加上volatile关键字后,第一条线程才能正确获得stop改变后的值,然后停止!(<.!.>)

lianbancai
lianbancai 不加Thread.sleep(2000)的时候,不管加不加volatile可以停止的
8 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问