一旦一個共享變量(類的成員變量、類的靜態成員變量)被 volatile 修飾以後,那麼就具有了兩層語義: 1)保證了不一樣線程對這個變量進行操做時的可見性,即一個線程修改了某個變量的值,這新值對其餘線程來講是當即可見的。 (讀取值時強行獲取主內存中的值,設置值時將工做內存的數據刷新到主內存中) 2)禁止進行指令重排序。 注意:不具有原子性,使用也有不少限制,須要原子性則能夠使用juc的鎖機制,如:synchronized,lock,AtomicBoolean等
volatitle經典案例: ide
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