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");

}
}

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