36套java进阶高级架构师视频+38套大数据视频 保证全是硬货需要的
+微信:
du13797566440
volatile的例子很难重现,因为只有在对变量读取频率很高的情况下,虚拟机才不会及时写回到主内存,而当频率没有达到虚拟机认为的高频率时,普通变量和volatile是同样的处理逻辑。
public class RunThread extends Thread{
private /*volatile*/ boolean isRunning = true; // 加上volatile关键字后强制其他线程到jvm主内存中重新读取
private void setRunning(boolean isRunning){
this.isRunning = isRunning;
}
public void run(){
System.out.println("进入run方法..");
int i = 0;
while(isRunning == true){
}
System.out.println("线程停止");
}
public static void main(String[] args) throws InterruptedException {
RunThread runThread = new RunThread();
runThread.start();
Thread.sleep(1000);
runThread.setRunning(false);
System.out.println(runThread);
}
}
控制台打印结果
进入run方法..
false
解决办法 :isRunning用 valatile修饰,不管isRunning强制从主内存中取