JVM笔记之运行时数据区域

JVM笔记之运行时数据区域

1.程序计数器

程序计数器是一块较小的内存区域,他可以看做是当前线程所执行的字节码的行号解释器。

每条线程都会有一个独立的程序计数器,各个线程互不影响,独立存储,这类内存区域叫做 ** “线程私有”**的内存。

2.java虚拟机栈

与程序计数器一样,java虚拟机栈也是线程私有的。

他的生命周期与线程相同。
虚拟机栈描述的是java方法执行的内存模型: 每个方法在执行的时候都会创建一个栈桢,用于存储局部变量表、操作数栈、动态链接、方法出口等,每一个方法从调用直到执行完成的过程,就对应着一个栈桢在虚拟机栈中入栈出栈的过程。
java 内存分为 堆内存 和 栈内存

栈内存(局部变量表)

局部变量表存储的是编译期可知的各种基本类型数据、对象引用类型。
其中64位的long和double类型的数据会占据2个局部变量空间(slot),其余占据一个局部变量空间,。
局部变量表所需内存空间在编译期完成分配。在运行时不会改变局部变量表的大小。

本地方法栈

与虚拟机栈提供的功能是类似的,虚拟机栈为虚拟机执行java方法服务,而本地方法栈则为native方法服务。

3. java堆

java堆是java虚拟机所管理的内存中最大的一块。

java堆是被所有线程共享的一块内存区域。在虚拟机启动的时候创建。

此区域的唯一目的就是存放对象实例、几乎所有的对象实例都在这里创建。
java堆是垃圾收集器管理的主要区域,很多时候也叫做 “GC堆”。
从内存回收的角度讲,由于现在都采用分代收集算法,所以:
java堆中还可以细分为: 新生代 和 老生代

4.方法区

是各个线程共享的内存区域,它用于存储已经被java虚拟机加载的类信息、常量、静态变量、即时编译后的代码等数据。

对方法区的限制非常宽松,除了和java堆一样不需要连续的内存空间和可以选择的固定大小或者可扩展外,还可以选择不实现垃圾收集。
这区域的回收主要针对常量池的回收和对类型的卸载。

5.运行时常量池

运行时常量池是方法区的一部分。
class文件中除了有类的版本、字段、方法、接口等描述信息,还有一项信息是常量池,用于存放编译期生成的各种字面量和符号引用,这部分内容将在类加载后进入方法区的运行时常量池中存放。

6.直接内存

就是系统中内存