1.JVM运行时数据区
2.内存模型JMM
(1)Meta Sapce:规避永久代溢出问题,可动态扩容
(2)新生代:eden,s0,s1 8:1:1 复制回收算法
(3)对象的生命周期不一样---分代
(4)98%对象在minor gc的时候会被回收掉,否则分配担保,新生代没有空间,放入老年代
(5)空间大小设置建议:新生代:老年代=1:2 定义大小:根据gc日志老年代活跃数据量300M,堆总设置300*4=1200M,新生代1.5倍=450M,老年代1200-450=750M
(6)什么样的对象需要被GC?
判断算法:引用计数法:相互引用,循环引用
可达性分析:gc root是否可到达方法
gc root有:虚拟机栈中本地变量表引用的对象(正在运行方法的对象);
方法区中类静态变量引用的对象,常量引用的对象;
本地方法栈中JNI引用的对象
不可达不一定会立即被回收:通过finalize()方法进行挽救;
待续......