synchronized与volatile
synchronized實(shí)現(xiàn)過(guò)程:
1.Java代碼:synchronized
2.字節(jié)碼層級(jí):monitorenter,monitorexit
3.執(zhí)行過(guò)程中自動(dòng)升級(jí)(偏向->自旋->重量級(jí)鎖)
4.cpu匯編層級(jí):lock comxchg
上圖為雙核cpu的內(nèi)部構(gòu)造,兩個(gè)核共享一個(gè)三級(jí)緩存
超線程:一個(gè)ALU對(duì)應(yīng)多個(gè)PC,一個(gè)核里面有兩個(gè)pc,線程切換時(shí)不用存之前線程的數(shù)據(jù),
直接兩個(gè)pc記錄運(yùn)行到哪了,切換節(jié)約時(shí)間。
從主存讀數(shù)據(jù)的時(shí)候,按塊讀(局部性原理)
這個(gè)塊叫cache line(緩存行),一行數(shù)據(jù)64字節(jié)
MESI Cache一致性協(xié)議:
modified修改,exclusive獨(dú)占,shared共享,invalid
Intel cpu是mesi緩存一致性協(xié)議,其他的cpu不一定
volatile怎么實(shí)現(xiàn)指令重排序?
1.volatile
2.字節(jié)碼層級(jí):ACC_VOLATILE
3.JVM層級(jí):JVM的內(nèi)存屏障
屏障兩邊的指令不可以重排!保障有序!
4.hotspotspot實(shí)現(xiàn)
總結(jié)
以上是生活随笔為你收集整理的synchronized与volatile的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 动态规划--Leetcode62--不同
- 下一篇: 关于信道和链路