jvm内存结构与java内存模型
前幾天在面試網易的時候被問到java內存結構與內存模型,傻傻分不清,其實JVM內存結構是與JVM的內部存儲結構相關,而java內存模型是與多線程有關。
JVM構成:
Java源代碼編譯成Java Class文件后通過類加載器ClassLoader加載到JVM中,其中
1、類存放在方法區中
2、類創建的對象存放在堆中
3、堆中對象的調用方法時會使用到虛擬機棧,本地方法棧,程序計數器
4、方法執行時每行代碼由解釋器逐行執行
5、熱點代碼由JIT編譯器即時編譯
6、垃圾回收機制回收堆中資源
7、和操作系統打交道需要調用本地方法接口
1、什么是Java內存模型(JMM)
????????通俗來說,JMM是一套多線程讀寫共享數據時,對數據的可見性,有序性和原子性的規則。
JVM實現不同會造成“翻譯”的效果不同,不同CPU平臺的機器指令有千差萬別,無法保證同一份代碼并發下的效果一致。所以需要一套統一的規范來約束JVM的翻譯過程,保證并發效果一致性。
2、JVM內存結構
由程序計數器,虛擬機棧,本地方法棧,堆,方法區構成。
程序計數器
- 程序計數器是線程私有的,每個線程單獨持有一個程序計數器
- 程序計數器不會內存溢出
- 通過移位寄存器實現
虛擬機棧
-
棧:線程運行需要的內存空間
-
棧幀:每一個方法運行需要的內存(包括參數,局部變量,返回地址等信息)
-
每個線程只有一 個活動棧幀(棧頂的棧幀),對應著正在執行的代碼
本地方法棧
- 本地方法棧為虛擬機使用到的 Native 方法服務
- Native 方法是 Java 通過 JNI 直接調用本地 C/C++ 庫,可以認為是 Native 方法相當于 C/C++ 暴露給 Java 的一個接口
- 如notify,hashcode,wait等都是native方法
堆
-
通過new關鍵字創建的對象都會使用堆內存
-
堆是線程共享的
-
堆中有垃圾回收機制
-
堆內存溢出(OutOfMemoryError)
-
堆內存診斷
-
命令行方式
-
jconsole
-
jvisualvm
方法區
????????方法區只是一種概念上的規范,具體的實現各種虛擬機和不同版本不相同
- HotSpot1.6 使用永久代作為方法區的實現
- HotSpot1.8使用本地內存的元空間作為方法區的實現(但StringTable還是放在堆中)
總結
以上是生活随笔為你收集整理的jvm内存结构与java内存模型的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Docker Swarm建立服务器集群
- 下一篇: 字符串格式化