JVM主要分为四部分:
1. 类加载器(Class Loader)
2. 运行时数据区(Runtime Data Area)
3. 执行引擎(Execution Engine)
4. 本地库接口(Native Interface)
其中,运行时数据区(内存布局)又分为程序计数器、虚拟机栈、本地方法栈、堆和方法区,其中,两栈一器私有,堆和方法区共享。
一、堆(线程共享)
堆中存放几乎所有对象实例,所有程序所创建的对象均保存在堆中。
二、Java虚拟机栈(线程私有)
虚拟机栈存放的是各类基本数据类型和对象的引用,包含四部分
1. 局部变量表: 存放了编译器可知的各种基本数据类型(8大基本数据类型)、对象引用。局部变量表所需的内存空间在编译期间完成分配,当进入一个方法时,这个方法需要在帧中分配多大的局部变量空间是完全确定的,在执行期间不会改变局部变量表大小。简单来说就是存放方法参数和局部变量。
2. 操作栈:每个方法会生成一个先进后出的操作栈。
3. 动态链接:指向运行时常量池的方法引用。
4. 方法返回地址:PC 寄存器的地址。
三、本地方法栈(线程私有)
本地方法栈和虚拟机栈类似,只不过虚拟机栈是给JVM使用的,本地方法栈是给本地方法使用的。
四、程序计数器(线程私有)
每条线程都有自己的程序计数器,用来记录代码执行到的位置(行号)
五、方法区(线程共享)
用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。
本文详细介绍了JVM的结构,重点解析了运行时数据区的各个组成部分,包括堆、虚拟机栈、本地方法栈、程序计数器和方法区。堆是所有对象实例的存储区域,虚拟机栈则由局部变量表、操作栈、动态链接和方法返回地址组成。本地方法栈服务于本地方法,程序计数器记录代码执行位置。方法区存储类信息和常量。这些组件共同构成了JVM内存模型的基础。
86万+

被折叠的 条评论
为什么被折叠?



