您好,登錄后才能下訂單哦!
一旦一個共享變量(類的成員變量、類的靜態成員變量)被 volatile 修飾之后,那么就具備了兩層語義:
1)保證了不同線程對這個變量進行操作時的可見性,即一個線程修改了某個變量的值,這新值對其他線程來說是立即可見的。
(讀取值時強行獲取主內存中的值,設置值時將工作內存的數據刷新到主內存中)
2)禁止進行指令重排序。
注意:不具備原子性,使用也有很多限制,需要原子性則可以使用juc的鎖機制,如:synchronized,lock,AtomicBoolean等
volatitle經典案例:
package test;
public class RunThread extends Thread {
/** volatile */
private /*volatile*/ boolean isRunning = true;
private void setRunning(boolean isRunning) {
this.isRunning = isRunning;
}
public void run() {
System.out.println(Thread.currentThread().getName()+" > start!!! 進入 run() 方法中...");
while (isRunning) {
}
System.out.println(Thread.currentThread().getName()+"> stop!!! 線程結束了..."+isRunning);
}
public static void main(String[] args) throws InterruptedException {
RunThread myThread = new RunThread();
myThread.start();
Thread.sleep(3000);
myThread.setRunning(false);
System.out.println(Thread.currentThread().getName()+"> isRunning 的值已經設置為了 false");
}
}
#不加volatile結果為:
Thread-0 > start!!! 進入 run() 方法中...
main> isRunning 的值已經設置為了 false
#加volatile結果為:
Thread-0 > start!!! 進入 run() 方法中...
main> isRunning 的值已經設置為了 false
Thread-0> stop!!! 線程結束了...false
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。