内存可见性(Memory Visibility)
1 内存可见性(Memory Visibility)是指当某个线程正在使用对象状态而另一个线程在同时修改该状态,需要确保当一个线程修改了对象状态后,其他线程能够看到发生的状态变化。
2 可见性错误是指当读操作与写操作在不同的线程中执行时,我们无法确保执行读操作的线程能适时地看到其他线程写入的值,有时甚至是根本不可能的事情。我们可以通过同步来保证对象被安全地发布。除此之外我们也可以使用一种更加轻量级的 volatile 变量。
volatile 关键字
Java 提供了一种稍弱的同步机制,即 volatile 变量,用来确保将变量的更新操作通知到其他线程。
可以将 volatile 看做一个轻量级的锁,但是又与锁有些不同:
对于多线程,不是一种互斥关系
不能保证变量状态的“原子性操作”
1,不使用volatile
package com.wangfubin; public class Main { public static void main(String[] args){ MyThread td=new MyThread(); new Thread(td).start(); while(true){ if(td.isFlag()){ System.out.println("-----------"); break; } } } } class MyThread implements Runnable{ private boolean flag=false; public void run() { try { Thread.sleep(200); } catch (InterruptedException e) { e.printStackTrace(); } flag=true; System.out.println("flag="+isFlag()); } public boolean isFlag(){ return flag; } public void setFlag(boolean flag){ this.flag=flag; } }

2,使用volatile
package com.wangfubin; public class Main { public static void main(String[] args){ MyThread td=new MyThread(); new Thread(td).start(); while(true){ if(td.isFlag()){ System.out.println("-----------"); break; } } } } class MyThread implements Runnable{ private volatile boolean flag=false; public void run() { try { Thread.sleep(200); } catch (InterruptedException e) { e.printStackTrace(); } flag=true; System.out.println("flag="+isFlag()); } public boolean isFlag(){ return flag; } public void setFlag(boolean flag){ this.flag=flag; } }
返回结果:
本文深入探讨Java中的内存可见性问题,解释了在多线程环境下如何确保一个线程对共享变量的修改能被其他线程及时看到。通过对比未使用Volatile和使用Volatile的代码示例,阐述了Volatile关键字在实现轻量级同步中的作用。
6976

被折叠的 条评论
为什么被折叠?



