JVM学习之运行时数据区(方法区、堆、虚拟机栈、本地方法栈、程序计数器)

运行时数据区

(程序运行时在jvm的一个状态;内存模型(JMM:分为metaspace和heap))
重点为 方法区、堆、虚拟机栈

JVM学习之运行时数据区(方法区、堆、虚拟机栈、本地方法栈、程序计数器)_第1张图片
左边是线程共享的(方法区、堆),右边是线程私有的(虚拟机栈、本地方法栈、计数器)
线程私有的生命周期都比较短

Method Area(方法区)

方法区是各个线程共享的内存区域,在虚拟机启动时创建。
用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。
方法区只有一个,线程共享的内存区域【线程非安全】,生命周期是跟虚拟机一样的

关键字:
jdk1.7 PermSpace—>永久代
jdk1.8 MetaSpace—>元空间

Heap(堆)

Java堆是Java虚拟机所管理内存中最大的一块,在虚拟机启动时创建,被所有线程共享。
Java对象实例以及数组都在堆上分配。
当方法区和堆内存不够了,都会出现OutOfMemoryError.

Java Virtual Machine Stacks(虚拟机栈)

虚拟机栈是一个线程执行的区域,保存着一个线程中方法的调用状态。换句话说,一个Java线程的运行
状态,由一个虚拟机栈来保存,所以虚拟机栈肯定是线程私有的,独有的,随着线程的创建而创建。
每一个被线程执行的方法,为该栈中的栈帧,即每个方法对应一个栈帧。
调用一个方法,就会向栈中压入一个栈帧;一个方法调用完成,就会把该栈帧从栈中弹出。
意为:一个线程的创建代表一个栈
每个方法被当前线程调用,就代表一个栈帧
如果栈不够用了,就会出现StackOverflowError,栈溢出

图解
JVM学习之运行时数据区(方法区、堆、虚拟机栈、本地方法栈、程序计数器)_第2张图片

The pc Register(程序计数器)

程序计数器占用的内存空间很小,由于Java虚拟机的多线程是通过线程轮流切换,并分配处理器执行时
间的方式来实现的,在任意时刻,一个处理器只会执行一条线程中的指令。因此,为了线程切换后能够
恢复到正确的执行位置,每条线程需要有一个独立的程序计数器(线程私有)。
如果线程正在执行Java方法,则计数器记录的是正在执行的虚拟机字节码指令的地址;
如果正在执行的是Native方法,则这个计数器为空。

Native Method Stacks(本地方法栈)

如果当前线程执行的方法是Native类型的,这些方法就会在本地方法栈中执行。

你可能感兴趣的:(JVM,JAVA,java,jvm)