JVM中的内存区域划分
JVM中的内存布局由以下五大部分组成:
堆(线程间共享)
堆主要存储程序创建的对象与对象的非静态成员变量.
堆中的新生代区与老生代区是在垃圾回收阶段中根据对象的存活时间来放入的.
虚拟机栈(每个线程独有一份)
虚拟机栈的作⽤:Java虚拟机栈的⽣命周期和线程相同,Java虚拟机栈描述的是Java⽅法执⾏的内存模型:每个⽅法在执⾏的同时都会创建⼀个栈帧(Stack Frame)⽤于存储局部变量表,操作数栈,动态链接,⽅法出⼝等信息。咱们常说的堆内存,栈内存中,栈内存指的就是虚拟机栈.
本地方法栈(每个线程独有一份)
本地⽅法栈和虚拟机栈类似,只不过Java虚拟机栈是给JV使⽤的,⽽本地⽅法栈是给本地⽅法使⽤的.
程序计数器(每个线程独有一份)
程序计数器的作⽤:⽤来记录当前线程执⾏的⾏号的.
程序计数器是⼀块⽐较⼩的内存空间,可以看做是当前线程所执⾏的字节码的⾏号指⽰器。
如果当前线程正在执⾏的是⼀个Java⽅法,这个计数器记录的是正在执⾏的虚拟机字节码指令的地址;如果正在执⾏的是⼀个Native⽅法,这个计数器值为空。
元数据区(线程间共享)
元数据区的作⽤:⽤来存储被虚拟机加载的类信息,常量,静态变量,即时编译器编译后的代码等数据的.
运行时常量池是元数据区的一个部分,class文件中除了有类的版本,字段,方法,接口等描述信息外,还有一项信息是常量池,用于存放编译期间生成的各种字面量和符号引用,这部分内容会在类加载后进入方法区的运行时常量池中.