本文已参与「新人创作礼」活动, 一起开启掘金创作之路。
jvm内存结构模型
类加载器
双亲委派机制
java的类加载中的刹箱加载机制
Java8后的jvm gc作用域在堆内存和方法区
常见的垃圾回收算法:
引用计数 复制 标记清除 标记整理
引用计数法有对象引用加个一没对象引用减个一
复制之后有交换,谁空谁是to
年轻代,幸存者一区和幸存者二区
MinorGC的过程(复制->清空->互换)
1: eden、 SurvivorFrom 复制到SurvivorTo,年龄+1
首先,当Eden区 满的时候会触发第一次GC,把还活 着的对象拷贝到SurvivorFrom区,当Eden 区再次触发GC的时候会扫描Eden区和From区域,对这两个区域进行垃圾回收,经过这次回 收后还存活的对象,则直接复制到To区域(如果有对象的年龄已经达到了老年的标准,则赋 值到老年代区),同时把这些对象的年龄+1
2:清空eden、 SurvivorFrom
然后,清空Eden和SurvivorFrom中的对象,也即复制之后有交换,谁空谁是toB: SurvivorTo和 SurvivorFrom互换
最后,SurvivorTo 和SurvivorFrom互换,原SurvivorTo成为 下一次GC时 的SurvivorFrom区。部
3: Survivor To和SurvivorFrom互换
最后,SuryivorTo 和SurvivorFrom互换,原SurvivorTo成为 下一次GC时 的SurvivorFrom区。部 分对象会在From和To区域中复制来复制去,如此交换15次(由JVM参数MaxTenuringThreshold 决定,这个参数默认是15),最终如果还是存活,就存入到老年代
标记清除 老年代
标记整理清除压缩 老年代
分代收集算法
当前商业虚拟机的垃圾收集都采用“分代收集”(Generational Collection)算法,这种算法并没有什么新的思想,只是根据对象存活周期的不同将内存划分为几块。一般是把Java堆分为新生代和老年代,这样就可以根据各个年代的特点采用最适合的收集算法。在新生代中,每次垃圾收集时都发现有大批对象死去,只有少量存活,那就选用复制算法,只需要付出少量存活对象的复制成本就可以完成。而老年代中因为对象存活率高、没有额外空间对他进行分配担保,就必须使用“标记-清理”或者“标记-整理”算法来进行回收。