JVM之运行时数据区

前言 :Java虚拟机在执行JAVA程序时,将内存分为若干个不同的数据区域,这些区域都有各自的用途,有的区域跟随的县城的启动和结束而建立和销毁,有的随着虚拟机进程启动而存在。

JVM之运行时数据区_第1张图片
运行时数据区由 程序计数器、java虚拟机栈、本地方法栈、堆
方法区构成

1.程序计数器

程序计数器占很小的内存空间,它可以看做是当前所执行的字节码的行号指示器 每条线程都需要一个独立的程序计数器,各个计数器之间互不影响。计数器记录的是正在执行的虚拟机字节码的地址。

2.java虚拟机栈

线程私有
java虚拟机栈描述的是内存模型 :每个方法在执行的同时会创建一个栈帧 用于存储**(局部变量表、操作数栈、动态链表、方法出口)**信息。每个方法从调用直至执行完成的过程,就对应着一个栈帧从入栈到出栈的过程
局部变量表存放:基本数据类型、对象引用、returnAddres(指向一条字节码指令的地址)信息。

3.本地方法栈

与java虚拟机栈功能类似,服务的方法不同、java虚拟机栈服务的是java方法。而本地方法栈服务的是native方法。

4. 堆

线程共享
是内存最大的一块。
功能:存放着对象实例,几乎所有的对象和实例都在这里分配内存。
从内存回收角度看 可以分为新生代、老年代或者Eden空间 、from survivor、to survivior

5.方法区

线程共享
功能:存储虚拟机加载类信息、常量、静态变量等数据
程序员更喜欢叫方法区为:永久代 因为GC分代收集扩展到方法区

运行时常量池是方法区的一部分:用于存放编译器生成的各种字面量和符号引用,这部分内容将在类加载后进入方法去的运行时常量中存放。

你可能感兴趣的:(JVM)