Java Volatile關(guān)鍵字同步機制詳解
Volatile關(guān)鍵字--最輕量級的同步機制1.保證了不同線程對這個變量進(jìn)行操作時的可見性,即一個線程修改了某個變量的值,這新值對其他線程來說是立即可見的。(實現(xiàn)可見性)
例如:如果一個oldvalue -->修改為newvalue ,這時的newvalue可以被其他的線程看到。
2.volatile不是線程安全的,只能保證對單次讀/寫的原子性。i++ 這種操作不能保證原子性。(不能保證原子性)最常使用場景:一寫多讀代碼演示Volatile的可見性
public class VolatileCase { //未加volatile關(guān)鍵字 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關(guān)鍵字運行結(jié)果:
加上Volatile關(guān)鍵字后:
//加volatile關(guān)鍵字 private volatile static boolean ready = false;
加上Volatile關(guān)鍵字運行結(jié)果:
綜上:
證實Volatile的可見性:當(dāng)一個線程修改一個Volatile修飾的變量時,其他線程可以實時看到。
代碼演示Volatile的非原子性:
public class VolatileCase { //Volatile關(guān)鍵字 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()); }}
第一次運行結(jié)果:
第二次運行結(jié)果:
正確的運行結(jié)果應(yīng)該是20000的,但是每次結(jié)果都少于20000,證實Volatile的非原子性和非線程安全。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. XML入門精解之結(jié)構(gòu)與語法2. CSS Hack大全-教你如何區(qū)分出IE6-IE10、FireFox、Chrome、Opera3. CSS3實例分享之多重背景的實現(xiàn)(Multiple backgrounds)4. 利用CSS3新特性創(chuàng)建透明邊框三角5. XML入門的常見問題(一)6. HTML5 Canvas繪制圖形從入門到精通7. 概述IE和SQL2k開發(fā)一個XML聊天程序8. HTML <!DOCTYPE> 標(biāo)簽9. HTML DOM setInterval和clearInterval方法案例詳解10. XML入門的常見問題(二)
