jvm运行时数据区组成
堆和方法区是线程共享; 虚拟机栈,本地方法栈,程序计算器是线程私有的。
-
方法区/永久代
方法区是堆的一个逻辑部分,又不等同于堆。堆主要存放对象实例。方法区存在对应附加的一些信息
如:类信息(类版本,方法,字段,接口等),常量,静态变量,编译后的代码等
可用以下参数调整:
jdk1.7及以前:-XX:PermSize;-XX:MaxPermSize;
jdk1.8以后:-XX:MetaspaceSize :-XX:MaxMetaspaceSize
jdk1.8以后大小就只受本地总内存的限制
如:-XX:MaxMetaspaceSize=3M
特殊的内存区域:
- 运行时常量池
-
堆内
是内存区域最大的一块,主要存储对象实例。原则上来说,所有的对象和数组都是在这里分配内存的。
是GC活动的主要区域,为了更好的分配内存,将堆分为新生代和老年代,Gc主要活跃为新生代区
-Xms:堆的最小值
-Xmx:堆的最大值
-Xmn:新生代的大小
-XX:NewSize:新生代的最小值
-XX:MaxNewSize :新生代的最大值
-
java虚拟机栈
是用来描述java方法执行的内存模型,每个方法在执行的同时创建一个栈帧,包括:局部变量表,操作数栈,动态链接,方法出入口信息。方法执行的过程其实就是栈帧在虚拟机栈入栈到出栈的过程。
局部变量表:面试中常说得堆和栈,一般说得就是虚拟机栈,更加具体的是说,虚拟机栈中局部变量表
局部变量存储的对象:1.基本数据类型(int,long,float)2.对象的引用,指向对象起始地址的引用地址,代表的对象句柄3.returnAddress指向了一条字节码地址
内存分配时间:编译期,当进入一个方法时,需要分配多少已经确定。
异常类型:1.当请求栈深度大于虚拟机栈允许的深度时-Xss10M,StackOverFlowError异常。栈桢大小缺省为1M,
可用参数 –Xss调整大小,例如-Xss256k
2.如果虚拟机栈可以动态扩展,当扩展时无法申请到足够的内存时,抛出OutOfMemoryError。
操作数栈:主要存放一些运算用到的参数,或者是中间结果。也有可能是调用其他方法时,需要用到的参数。
动态链接:在常量池中有大量的符号引用,在运行期间转换为直接引用,那么这种转换就是动态链接
-
本地方法栈
服务于native方法,有些虚拟机是把虚拟机栈和本地方法栈合并成一个
-
程序计数器
是内存最小的一块区域,负责记录当前线程所执行字节码的行号。是唯一一块不会出现OutOfMemoryError的区域
程序运行java方法时,程序计数器记录的是,当前正在执行的虚拟机字节码指令地址,执行native方法时,计数器为空