深入理解java虚拟机-java内存结构(1)

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