更新時間:2020-10-12 17:47:24 來源:動力節(jié)點(diǎn) 瀏覽1290次
在多線程編程中,線程之間的通信是我們必須掌握的重難點(diǎn)知識。為了更好的實現(xiàn)程序的高并發(fā)、高性能、高可用,就不得不知道JMM,我們需要思考JMM和JVM關(guān)系,才能掌握好線程之間的通信這一重點(diǎn)內(nèi)容。
下面我們就來詳細(xì)的探究一下JVM和JMM區(qū)別:
一、 JVM
JVM的內(nèi)部結(jié)構(gòu)如下圖所示,這張圖很清楚形象的描繪了整個JVM的內(nèi)部結(jié)構(gòu),以及各個部分之間的交互和作用。
1 Class Loader(類加載器)就是將Class文件加載到內(nèi)存,再說的詳細(xì)一點(diǎn)就是,把描述類的數(shù)據(jù)從Class文件加載到內(nèi)存,并對數(shù)據(jù)進(jìn)行校驗、轉(zhuǎn)換解析和初始化,最終形成可以被虛擬機(jī)直接使用的Java類型,這就是類加載器的作用。
2 Run Data Area(運(yùn)行時數(shù)據(jù)區(qū)) 就是我們常說的JVM管理的內(nèi)存了,也是我們這里主要討論的部分。運(yùn)行數(shù)據(jù)區(qū)是整個JVM的重點(diǎn)。我們所有寫的程序都被加載到這里,之后才開始運(yùn)行。這部分也是我們這里將要討論的重點(diǎn)。
3 Execution engine(執(zhí)行引擎) 是Java虛擬機(jī)最核心的組成部分之一。執(zhí)行引擎用于執(zhí)行指令,不同的java虛擬機(jī)內(nèi)部實現(xiàn)中,執(zhí)行引擎在執(zhí)行Java代碼的時候可能有解釋執(zhí)行(解釋器執(zhí)行)和編譯執(zhí)行(通過即時編譯器產(chǎn)生本地代碼執(zhí)行,例如BEA JRockit),也有可能兩者兼?zhèn)洹H魏蜫VM specification實現(xiàn)(JDK)的核心都是Execution engine,不同的JDK例如Sun 的JDK 和IBM的JDK好壞主要就取決于他們各自實現(xiàn)的Execution engine的好壞。
4 .Native interface 與native libraries交互,是其它編程語言交互的接口。當(dāng)調(diào)用native方法的時候,就進(jìn)入了一個全新的并且不再受虛擬機(jī)限制的世界,所以也很容易出現(xiàn)JVM無法控制的native heap OutOfMemory。
二、JMM
Java內(nèi)存模型(Java Memory Model,JMM)主要是為了規(guī)定了線程和內(nèi)存之間的一些關(guān)系。根據(jù)JMM的設(shè)計,系統(tǒng)存在一個主內(nèi)存(Main Memory),Java中所有變量都儲存在主存中,對于所有線程都是共享的。每條線程都有自己的工作內(nèi)存(Working Memory),工作內(nèi)存中保存的是主存中某些變量的拷貝,線程對所有變量的操作都是在工作內(nèi)存中進(jìn)行,線程之間無法相互直接訪問,變量傳遞均需要通過主存完成。
1、JMM定義了Java 虛擬機(jī)(JVM)在計算機(jī)內(nèi)存(RAM)中的工作方式。JVM是java整個計算虛擬模型。
2、從抽象的角度來看,JMM定義了線程和主內(nèi)存之間的抽象關(guān)系:線程之間的共享變量存儲在主內(nèi)存(Main Memory)中,每個線程都有一個私有的本地內(nèi)存(Local Memory),本地內(nèi)存中存儲了該線程以讀/寫共享變量的副本。
3、本地內(nèi)存是JMM的一個抽象概念,并不真實存在。它涵蓋了緩存、寫緩沖區(qū)、寄存器以及其他的硬件和編譯器優(yōu)化。
三、JVM和JMM關(guān)系
JMM中的主內(nèi)存、工作內(nèi)存與JVM中的Java堆、棧、方法區(qū)等并不是同一個層次的內(nèi)存劃分,這兩者基本上是沒有關(guān)系的,如果兩者一定要勉強(qiáng)對應(yīng)起來,那從變量、主內(nèi)存、工作內(nèi)存的定義來看,主內(nèi)存主要對應(yīng)于Java堆中的對象實例數(shù)據(jù)部分,而工作內(nèi)存則對應(yīng)于虛擬機(jī)棧中的部分區(qū)域。從更低層次上說,主內(nèi)存就直接對應(yīng)于物理硬件的內(nèi)存,而為了獲取更好的運(yùn)行速度,虛擬機(jī)(甚至是硬件系統(tǒng)本身的優(yōu)化措施)可能會讓工作內(nèi)存優(yōu)先存儲于寄存器和高速緩存中,因為程序運(yùn)行時主要訪問讀寫的是工作內(nèi)存。
看完了本文,我們對于JVM和JMM都有了一定程度上的了解,也知道了JMM和JVM關(guān)系的微秒,想要更好的學(xué)習(xí)JVM和JMM的知識,推薦大家觀看本站的Java零基礎(chǔ)教程,里面對這些Java基礎(chǔ)知識的講解一步到位,讓你不再為學(xué)習(xí)Java犯愁,動力節(jié)點(diǎn)是你學(xué)習(xí)Java的最佳選擇!
0基礎(chǔ) 0學(xué)費(fèi) 15天面授
有基礎(chǔ) 直達(dá)就業(yè)
業(yè)余時間 高薪轉(zhuǎn)行
工作1~3年,加薪神器
工作3~5年,晉升架構(gòu)
提交申請后,顧問老師會電話與您溝通安排學(xué)習(xí)
初級 202925
初級 203221
初級 202629
初級 203743