文章目录
JVM内存模型
JVM内存模型分为堆(heap)、元空间、栈、本地方法栈、程序计数器。
JDK8的内存模型如下图:
堆和元空间是线程共享的,在Java虚拟机中只有一个堆、一个元空间,并在JVM启动的时候就创建,JVM停止才销毁。
栈、本地方法栈、程序计数器是每个线程私有的,随着线程的创建而创建,随着线程的结束而死亡。
1. 本地方法栈
提供虚拟机使用到的本地Native方法服务。
2. 程序计数器(Program Counter Register)
每个线程在创建后,都会产生自己的程序计数器和栈。程序计数器是一块较小的内存空间。由于CPU时间片轮限制,众多线程在并发执行过程中,处理器只会执行某个线程中的一条指令,这样必然涉及线程的切换。
程序计数器用来存放下一个执行指令的行号。线程恢复要依赖程序计数器。此区域不会发生内存溢出异常。
3. 线程栈(Stack)
JVM中的线程栈是描述Java方法执行的内存区域,它是线程私有的。每一个方法被调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程。
栈帧存储着局部变量、操作数栈、动态链接、方法出口等信息,局部变量存储方法内的局部变量,操作数栈用来计算时临时存放变量,动态链接存放方法的元信息等,方法出口记录如哪个方法的本方法等。通过javap -c XX.class查看字节码文件。