目录
深入JVM 原理(一)Java内存模型:https://blog.csdn.net/qq_39827935/article/details/81285009
深入JVM原理(二)Java对象访问模式:https://blog.csdn.net/qq_39827935/article/details/81285038
深入JVM原理(三)JVM 垃圾收集:https://blog.csdn.net/qq_39827935/article/details/81285059
深入JVM原理(四)JVM垃圾回收流程:https://blog.csdn.net/qq_39827935/article/details/81285084
深入JVM原理(五)Java堆内存调整参数(调优关键):https://blog.csdn.net/qq_39827935/article/details/81285099
深入JVM原理(六)年轻代:https://blog.csdn.net/qq_39827935/article/details/81285115
深入JVM原理(七)老年代、永久代和元空间:https://blog.csdn.net/qq_39827935/article/details/81285133
深入JVM原理(八)JVM垃圾回收策略:https://blog.csdn.net/qq_39827935/article/details/81285156
深入JVM原理(九)JVM垃圾回收策略参数配置:https://blog.csdn.net/qq_39827935/article/details/81285175
深入JVM原理(十)G1收集器:https://blog.csdn.net/qq_39827935/article/details/81285207
深入JVM原理(十一)Java引用类型:https://blog.csdn.net/qq_39827935/article/details/81285227
所有的新对象都会在年轻代产生,如果年轻代的空间不足,无法产生对象,则会引发 小GC和主GC(全GC)。
存活区会分为两个相等大小的存活区,所有使用关键字new新实例化的对象,一定会在伊甸园区进行保存。而对于存活区保存的一定是在伊甸园区保存好久,并且经过了好几次的小GC还保存下来的活跃对象。那么这个对象将晋升到存活区中,存活区一定会有两块大小相等的空间。目的是一块存活区未来晋升,另外一块存活区为了对象回收。这两块内存空间一定有一块是空的。
在年轻代中使用的是MinorGC,这种GC采用的是复制算法;
把一个空间的数据复制到另一个空间,然后进行清除,腾出空间。
根集合扫描:
通过以上的分析可以发现,伊甸园区中保存的对象,大部分都是临时对象,则极可能频繁产生小GC,所以在HotSpot虚拟机中为了加快此空间的内存分配形式,所以产生了两者技术:
范例:改变存活区的比例(-Xms10M -Xmx10M -XX:SURvivorRatio = 6 -XX:+ PrintGCDetails)
大部分情况无需改动;
年轻代的GC是小GC,小GC的算法是复制算法;
总有一个存活区是空的,两个存活区的大小是相同的;伊甸园和存活区的比例是8:1:1,这个比例一般情况下无需改动;