1.JVM运行时数据区

认识JVM及优化

2.内存模型JMM

认识JVM及优化

认识JVM及优化

    (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()方法进行挽救;

待续......

 

相关文章: