原文參考: http://blog.csdn.net/c504665913/article/details/8262127 ?
- PC寄存器(PC register):每個線程啟動的時候,都會創建一個PC(Program Counter ,程序計數器)寄存器。PC寄存器里保存有當前正在執行的JVM指令的地址。
- JVM 堆棧(JVM stack):每個線程啟動的時候,都會創建一個JVM堆棧。它是用來保存棧幀的。JVM只會在JVM堆棧上對棧幀進行push和pop的操作。如果出現了異常,堆棧跟蹤信息的每一行都代表一個棧幀立的信息,這些信息它是通過類似于printStackTrace()這樣的方法來展示的。
-
- 棧幀(stack frame):
- 每當一個方法在JVM上執行的時候,都會創建一個棧幀,并且會添加到當前線程的JVM堆棧上。當這個方法執行結束的時候,這個棧幀就會被移除。每個棧幀里都包含有當前正在執行的方法所屬類的本地變量數組,操作數棧,以及運行時常量池的引用。本地變量數組的和操作數棧的大小都是在編譯時確定的。因此,一個方法的棧幀的大小也是固定不變的。
- 局部變量數組(Local variable array):
- 這個數組的索引從0開始。索引為0的變量表示這個方法所屬的類的實例。從1開始,首先存放的是傳給該方法的參數,在參數后面保存的是方法的局部變量。
- 操作數棧(Operand stack):
- 方法實際運行的工作空間。每個方法都在操作數棧和局部變量數組之間交換數據,并且壓入或者彈出其他方法返回的結果。操作數棧所需的最大空間是在編譯期確定的。因此,操作數棧的大小也可以在編譯期間確定。
- 本地方法棧(Native method stack):
- 供用非Java語言實現的本地方法的堆棧。換句話說,它是用來調用通過JNI(Java Native Interface Java本地接口)調用的C/C++代碼。根據具體的語言,一個C堆棧或者C++堆棧會被創建。
- 方法區(Method area):
- 方法區是所有線程共享的,它是在JVM啟動的時候創建的。它保存所有被JVM加載的類和接口的運行時常量池,成員變量以及方法的信息,靜態變量以及方法的字節碼。JVM的提供者可以通過不同的方式來實現方法區。在Oracle 的HotSpot JVM里,方法區被稱為永久區或者永久代(PermGen)。是否對方法區進行垃圾回收對JVM的實現是可選的。
- 運行時常量池(Runtime constant pool):
- 這個區域和class文件里的constant_pool是相對應的。這個區域是包含在方法區里的,不過,對于JVM的操作而言,它是一個核心的角色。因此在JVM規范里特別提到了它的重要性。除了包含每個類和接口的常量,它也包含了所有方法和變量的引用。簡而言之,當一個方法或者變量被引用時,JVM通過運行時常量區來查找方法或者變量在內存里的實際地址。
- 堆(Heap):
- 用來保存實例或者對象的空間,而且它是垃圾回收的主要目標。當討論類似于JVM性能之類的問題時,它經常會被提及。JVM提供者可以決定怎么來配置堆空間,以及不對它進行垃圾回收。
-
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
