volatile关键字,使一个变量在多个线程间可见,
A,B线程都用一个变量,java默认是A线程中保留一份copy。
这样如果b线程修改了该变量,则a未必知道
使用volatile关键字,会让所有线程都会读到变量的修改值。
在下面的代码中,running是存在堆内存的t对象中,
当线程t1开始运行的时候,会把running值从内存中读到t1线程的工作区,在运行过程中直接使用这个copy,并不会每次都区读取堆内存。
这样,当主线程修改running的值之后,t1线程感知不到,所以不会停止运行
使用volatile关键字,将会强制所有线程都去堆内存中读取running的值,就是一个线程修改了变量,会通知别的线程数据的变更
但是volatile并不能保证多个线程共同修改running变量是所带来的不一致问题,当一个线程修改完毕,重新提交到内存中的时候,并不会校验,而是直接覆盖,也就是说volatile不能替代synchronized,但是效率比synchronized高很多
public class T{
/*volatile*/ boolean running=true;
void m(){
System.out.println("m start");
while(running){
}
System.out.println("m end");
}
public static void main(String[] args) {
T t=new T();
new Thread(t::m,"t1").start();
try{
TimeUnit.SECONDS.sleep(1);
}catch(InterruptedException e){
}
t.running=false;
}
}