JVM體繫結構圖 Native Interface(本地介面) Java本地介面(Java Native Interface (JNI))允許運行在Java虛擬機(Java Virtual Machine (JVM))上的代碼調用本地程式和類庫,或者被它們調用,這些程式和類庫可以是其它語言編寫的,比 ...
JVM體繫結構圖
Native Interface(本地介面)
Java本地介面(Java Native Interface (JNI))允許運行在Java虛擬機(Java Virtual Machine (JVM))上的代碼調用本地程式和類庫,或者被它們調用,這些程式和類庫可以是其它語言編寫的,比如C、C++或者彙編語言。
Program Counter Register(程式計數器)
每個線程都有一個程式計數器,是線程私有的,就是一個指針,指向方法區中的方法位元組碼(用來存儲指向下一條指令的地址),由執行引擎讀取下一條指令,是一個非常小的記憶體空間,幾乎可以忽略不計。
這塊n記憶體區域很小,它是當前線程所執行的位元組碼的行號指示器,位元組碼解釋器通過改變這個計數器的值來選取下一條需要執行的位元組碼指令。如果是一個native方法,那麼這個計數器就是空的。因為native方法是java通過JNI直接調用本地C/C++庫,可以近似的認為native方法相當於C/C++暴露給java的一個介面,java通過調用這個介面從而調用到C/C++方法。由於該方法是通過C/C++而不是java進行實現。那麼自然無法產生相應的位元組碼,並且C/C++執行時的記憶體分配是由自己語言決定的,而不是由JVM決定的。
Native Method Stack(本地方法棧)
本地方法棧的功能和特點類似於虛擬機棧,均具有線程隔離的特點以及都能拋出StackOverflowError和OutOfMemoryError異常。
不同的是,本地方法棧服務的對象是JVM執行的native方法,而虛擬機棧服務的是JVM執行的java方法。如何去服務native方法?native方法使用什麼語言實現?怎麼組織像棧幀這種為了服務方法的數據結構?虛擬機規範並未給出強制規定,因此不同的虛擬機實可以進行自由實現,我們常用的HotSpot虛擬機選擇合併了虛擬機棧和本地方法棧。
Method Area(方法區)
方法區是一個被線程共用的記憶體區域。其中主要存儲載入的類位元組碼、class/method/field等元數據對象、static-final常量、static變數、jit編譯器編譯後的代碼等數據。另外,方法區包含了一個特殊的區域“運行時常量池”。
Heap(堆)
堆是 JVM 管理的最大的一塊記憶體空間,主要用於存放Java類的實例對象.
Java Stack(java棧)
棧也叫棧記憶體,主管java程式的運行,是線上程創建時創建,它的生命期是跟隨線程的生命期,線程結束棧記憶體也就釋放,對於棧來說不存在垃圾回收問題,只要線程一結束該棧就Over,聲明周期和線程一致,是線程私有的。8中基本類型的變數+對象的引用變數+實例方法都是在函數的棧記憶體中分配。