您好,登錄后才能下訂單哦!
這篇文章主要講解了Java Volatile關鍵字同步機制的用法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
Volatile關鍵字--最輕量級的同步機制1.保證了不同線程對這個變量進行操作時的可見性,即一個線程修改了某個變量的值,這新值對其他線程來說是立即可見的。(實現可見性)
例如:如果一個oldvalue -->修改為newvalue ,這時的newvalue可以被其他的線程看到。
2.volatile不是線程安全的,只能保證對單次讀/寫的原子性。i++ 這種操作不能保證原子性。(不能保證原子性)最常使用場景:一寫多讀代碼演示Volatile的可見性
public class VolatileCase { //未加volatile關鍵字 private static boolean ready = false; private static int number = 0; private static class ThreadInfo extends Thread{ @Override public void run() { System.out.println("Thread start"); while (!ready); System.out.println("number:"+number+"----ready:"+ready+"Thread end"); } } public static void main(String[] args) throws InterruptedException { new ThreadInfo().start(); Thread.sleep(100); ready = true; number = 123; Thread.sleep(100); System.out.println("main end"); } }
未加Volatile關鍵字運行結果:
加上Volatile關鍵字后:
//加volatile關鍵字 private volatile static boolean ready = false;
加上Volatile關鍵字運行結果:
綜上:
證實Volatile的可見性:當一個線程修改一個Volatile修飾的變量時,其他線程可以實時看到。
代碼演示Volatile的非原子性:
public class VolatileCase { //Volatile關鍵字 private volatile int count = 0; public int getCount() { return count; } public void setCount(int count) { this.count = count; } public void inCount(){ count++; } private static class ThreadInfo extends Thread{ private VolatileCase vc; public ThreadInfo(VolatileCase vc){ this.vc = vc; } @Override public void run() { for (int i = 0; i < 10000; i++) { vc.inCount(); } } } public static void main(String[] args) throws InterruptedException { VolatileCase vc = new VolatileCase(); ThreadInfo threadInfo1 = new ThreadInfo(vc); ThreadInfo threadInfo2 = new ThreadInfo(vc); threadInfo1.start(); threadInfo2.start(); Thread.sleep(100); System.out.println("main end:"+vc.getCount()); } }
第一次運行結果:
第二次運行結果:
正確的運行結果應該是20000的,但是每次結果都少于20000,證實Volatile的非原子性和非線程安全。
看完上述內容,是不是對Java Volatile關鍵字同步機制的用法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。