JVM内存模型
运行时数据区:栈,堆,本地方法栈,方法区,程序计数器
栈
-
程序在执行时,首先会在栈中开辟一个方法栈空间,空间中存储局部变量表、操作数栈、动态链接和方法出口。
-
当程序执行到此方法时,就会把存储在操作数栈的数据放到对应的局部变量表中去。
-
动态链接就是指我们的引用的方法名是符号,我们通过符号找到对应的方法,得到对应的方法内部代码。
-
方法出口:局部方法执行完之后,返回主方法(main方法)
堆
new 出来的对象存储在堆内存空间中,栈中的局部变量表存储了对应堆内存空间的引用地址
堆中区域分年轻代和老年代
GC垃圾回收
可达性分析算法:
设置根节点,GC root 对象作为起点,从这些节点开始向下搜索引用对象,找到的对象标记为垃圾对象,其余的标记为非垃圾对象。
自己的理解:通过栈中的局部变量,去堆中查找垃圾对象,但凡没有指针指向此对象的,标记为垃圾对象,进行回收,其他有引用的标记为非垃圾对象。
full GC
当老年代放满之后,full GC就会回收我们的堆内存空间
STW
用户在使用过程中,程序会偶尔卡顿一下,GC线程此时在后台遍历所有的对象,进程进行垃圾回收操作。
此处的卡顿就是为了防止在回收的过程中,用户操作页面,产生新的对象或引用产生,导致重复的进行遍历标识是否为垃圾。
方法区
存储:常量 + 静态常量 + 类信息
jdk1.7及以前,称为老年代
jdk1.8及以后,称为元空间
本地方法栈
native修饰的本地方法 C语言编写
JVM的优化
优化的目的本质:是为了减少GC和full GC
调优的本质:就是通过自己计算,合理分配内存空间
full GC 是几天或者几周执行一次,如果经常执行,也就是页面经常卡顿,就说明配置有问题,或代码有问题