java volatile线程可见_volatile-验证线程之间的可见性
由于JVM運行程序的實體是線程,而每個線程創建時JVM都會為其創建一個工作內存(有些地方稱為棧空間),工作內存是每個線程的私有數據區域,而Java內存 模型中規定所有變量都存儲在主內存,主內存是共享內存區域,所有線程都可以訪問,但線程對變量的操作(讀取賦值等)必須在工作內存中進行,首先要將變量從主內存拷貝的自己的工作內存空間,然后對變量進行操作,操作完成后再將變量寫回主內存,不能直接操作主內存中的變量,各個線程中的工作內存中存儲著主內存中的變量副木拷貝,因此不同的線程間無法訪問對方的工作內存,線程間的通信(傳值)必須通過主內存來完成,其簡要訪問過程如下圖:
代碼驗證如下:
importjava.util.concurrent.TimeUnit;classMyData{//定義初始參數,volatile關鍵字使用為重點
volatile int number = 0;//更改初始參數
public voidchangeNumber(){this.number = 60;
}
}public classVolatileDemo {public static voidmain(String[] args) {//初始化資源類
MyData myData = newMyData();new Thread(() ->{
System.out.println(Thread.currentThread().getName()+"初始化線程,初始參數為:"+myData.number);//AAA線程暫停三秒后
try{
TimeUnit.SECONDS.sleep(3);
}catch(Exception e){
e.printStackTrace();
}//AAA線程更改初始化參數為60
myData.changeNumber();
System.out.println(Thread.currentThread().getName()+"線程更改初始化參數為:"+myData.number);
},"AAA").start();while(myData.number == 0){//第二個線程是main線程,在number=0時則一直陷入死循環,當number=60時則打印主線程語句。
}
System.out.println(Thread.currentThread().getName()+"主線程當前參數:"+myData.number);
}
}
結果展示:
1.初始參數number未加上volatile:
2.初始參數number加上volatile:
總結:
volatile是JAVA虛擬機提供的輕量級的同步機制,volatile三大特征:保證可見性,不保證原子性,禁止指令重排。
總結
以上是生活随笔為你收集整理的java volatile线程可见_volatile-验证线程之间的可见性的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java new thread参数_ja
- 下一篇: java 储存过程_Java储存过程