更新時間:2020-10-09 17:25:49 來源:動力節(jié)點 瀏覽1567次
?由于不同平臺內(nèi)存模型的差異,有可能導(dǎo)致程序在不同平臺的并發(fā)訪問出錯。Java內(nèi)存模型(Java Memory Model,JMM)是屏蔽各種硬件和操作系統(tǒng)的內(nèi)存訪問差異,以實現(xiàn)讓Java程序在各種平臺下都能達(dá)到一致的內(nèi)存訪問效果。而JVM內(nèi)存模型無疑是Java內(nèi)存模型的一個很好的體現(xiàn)方式。
1.JVM內(nèi)存模型具體操作
定義程序中各個變量的訪問規(guī)則,即在虛擬機(jī)中將變量存儲到內(nèi)存和從內(nèi)存中取出變量的底層細(xì)節(jié)。
此處的變量是指實例字段,靜態(tài)字段和構(gòu)成數(shù)組對象的元素,不包括局部變量與方法參數(shù)。
2.JVM內(nèi)存模型主內(nèi)存和工作內(nèi)存
JVM內(nèi)存模型規(guī)定所有的變量都存儲在主內(nèi)存中,每條線程還有自己的工作內(nèi)存,工作內(nèi)存保存了被該線程使用到的變量的主內(nèi)存副本拷貝。
3. synchronization、final、volatile
(1) synchronization
① 互斥
????對于一個monitor對象,當(dāng)被一個線程持有,其他線程只能等待
② 可見性
????保證了線程在同步代碼塊期間寫入動作,對于后續(xù)進(jìn)入該代碼塊的線程是可見的(持有相同monitor對象的線程)。
????當(dāng)前線程釋放monitor對象,作用是把cpu緩存數(shù)據(jù)刷新到主內(nèi)存中;其他線程進(jìn)入該代碼塊時,需要獲取monitor對象,會使cpu緩存失效,從而使變量從主內(nèi)存中重新加載。
③ 禁止指令重排序
(2) final
① 禁止指令重排序
② 可見性
????被final修飾的字段在構(gòu)造器中一旦初始化完成,并且構(gòu)造器沒有把”this”引用傳遞出去(“this”引用逃逸是一件很危險的事情,其他線程有可能通過這個引用訪問到”初始化了一半”的對象),那么其他線程就能看見final字段的值。
(3) volatile
① 可見性
② 禁止指令重排序
4.JVM內(nèi)存模型示例
(1) 重排序
(2) 可見性
(3) 互斥性
以上就是對JVM內(nèi)存模型的全面解析,相信即使是之前對JVM完全沒有了解的小伙伴在看完本文后,也會有不小的收獲,對JVM感興趣的小伙伴可以觀看本站的Java零基礎(chǔ)教程,學(xué)習(xí)更多這方面的專業(yè)知識。