synchronized 鎖住的是變量和變量的操作,而volatile鎖住的只是變量,而且該變量的值不能依賴它本身的值 volatile算是一種輕量級的同步鎖
2015-10-22
當一個線程訪問object的一個synchronized(this)同步代碼塊時,另一個線程仍然可以訪問該object中的非synchronized(this)同步代碼塊。
當兩個并發(fā)線程訪問同一個對象object中的這個synchronized(this)同步代碼塊時,一個時間內(nèi)只能有一個線程得到執(zhí)行。另一個線程必須等待當前線程執(zhí)行完這個代碼塊以后才能執(zhí)行該代碼塊。
解決讀取 半個變量的情況應該是加 synchronized關(guān)鍵字,volatile不不保證原子性的。。
2015-08-30
volatile和synchronized 的最大區(qū)別就是 前者不能保證變量或者代碼操作的原子性,而后者可以。。。原子性:要么操作完全,要么不操作。即,要么操作為1要么為0。。而volatile可能值執(zhí)行某項操作的一部分,比如 操作了0.6,這樣子,算什么事兒嘛,對吧。。所以,這個就是區(qū)別。。。
個人總結(jié),如有錯誤,望批評指正。發(fā)私信
個人總結(jié),如有錯誤,望批評指正。發(fā)私信
2015-08-30
因為線程的執(zhí)行本身就是不確定的,加了synchronized關(guān)鍵字只能確?;コ庠L問這段代碼以及變量的可見性,即某線程在修改共享變量(通過自己的工作內(nèi)存來修改)時,其他的所有線程無法獲得共享變量的信息。所以synchronized并不能保證程序的執(zhí)行順序。所以即使加了synchronized也可能會出現(xiàn)0。順序是隨機的,看jVM內(nèi)存以及CUP的調(diào)度了。
2015-08-30