深入理解java虚拟机-java内存结构(1)
其他
2018-11-26 09:31:13
阅读次数: 0
JVM内存空间布局 如下图(基于JDK1.7)
program connter register(程序计数器):
用来指示当前线程执行字节码的行号,如果是native方法计数器的值为空。
VM stack(虚拟机栈):
虚拟机栈是当前线程的独立一个空间,栈中方法的调用都会创建一个栈帧,栈帧中会有
局部变量表(用来存储编译期可知引用或者值,单位slot,long double占两个slot),操作数栈,方法出口等信息,局部变量表大小在编译期间就可知,因为具体要占用多少个slot,在写完方法后,就已经知道了,slot是会复用的,比如这个slot已经不用了,后面其他的变量是可以继续使用这个slot的。
native method stack(本地方法栈):虚拟机使用native方法的时候的栈,hotspot吧虚拟机栈和本地方法栈 二合一了。
heap 堆:
对象和数组都在堆中分配,也是jvm管理的最大一块内存空间,堆中也可能会有线程私有的分配缓冲空间,TLAB,当前线程创建对象会在TLAB中创建,
method area:方法区
存放已被虚拟机加载的 类信息,常量,静态变量,JIT编译后的代码,1.7中字符串常量已经移到堆中了、
direct memory:直接内存
不是jvm运行时的数据,nio可以直接通过native方法直接分配堆外内存。
转载自blog.csdn.net/woyixinyiyi/article/details/84503786