JVM内存结构:和Java虚拟机的运行时区域有关,JVM内存结构主要有三大块
- 堆内存
- 堆内存是JVM中最大的一块,有年轻代和老年代组成
- 年轻代又被分成Eden空间、From Survivor空间、To Survivor空间,默认按8:1:1比例分配
- Java堆是GC的主要区域,因此也被称为GC堆
- 如果没有可用内存则抛出OutOfMemoryError
- 方法区
- 各个线程共享的区域,主要存储已被虚拟机加载的类信息、常量、静态变量
- 方法区有一个别名叫做Non-Heap(非堆),目的是与Java堆区分开
- 方法区又被称为永久代(Permanent Generation),仅仅是因为HotSpot虚拟机将GC扩展至方法区
- 栈(线程私有)
- 程序计数器(Program Counter Register):记录当前执行字节码的行号(执行Native方法时值为Undefined),此区域不会发生OOM
- JVM栈:生命周期与线程相同,虚拟机栈描述的是Java方法执行的内存模型,每个方法被执行的时候都会同时创建一个**栈帧(Stack Frame)**用于存储局部变量表、操作栈、动态链接、方法出口等
- 本地方法栈:与JVM栈类似,区别是JVM栈执行的是Java方法,而本地方法栈执行的是Native方法
- JVM栈和本地方法栈都会抛出StackOverflowError和OutOfMemoryError
- 控制参数:
- -Xms 设置堆的最小空间
- -Xmx 设置堆的最大空间
- -XX:NewSize 设置新生代的最小空间
- -XX:MaxNewSize 设置新生代的最大空间
- -XX:PermSize 设置永久代的(方法区)的最小空间
- -XX:MaxPermSize 设置永久代的最大空间大小
- -Xss 设置每个线程的堆栈大小
- 没有直接设置老年代的参数,老年代大小 = 堆空间大小 - 年轻代空间大小
- 参考https://www.cnblogs.com/ityouknow/p/5610232.html