面试知识汇总——垃圾回收器(分代收集算法)

分代收集算法

根据对象的存活周期,把内存分成多个区域,不同区域使用不同的回收算法回收对象。

对象在创建的时候,会先存放到伊甸园。当伊甸园满了之后,就会触发垃圾回收。

这个回收的过程是:把伊甸园中的对象拷贝到From survivor或者是To survivor里面去。如果第一次回收把对象拷贝到From survior里了,那么下一次回收就会把存活的对象从From survior拷贝到To survior,再下一次就会把To survior里的对象拷贝到From surivor,周而复始。那么不难发现,这个过程使用了复制算法,这也就是为什么新生代要有两个survior的原因。

那么对象每经历一次垃圾回收之后,那么还存活的话,他的年龄就会加一。当对象的年龄达到阈值的话(默认是15),就会晋升到老年代,老年代里的对象存活率是比较高的。

老年代一般是采用标记清除或者标记整理的思想进行回收。

新建的对象不一定会分配到伊甸园,也有可能直接分配到老年代,这里主要分为两种场景:

  1. 对象大于-XX:PretenureSizeThreshold(默认是0),就会直接分配到老年代
  2. 新生代空间不够,如果你的对象非常的大,比如是一个超大数组,新生代的空间根本不够,那么这个时候也会直接放到老年代。因为新生代采用的是复制算法,在伊甸园分配大对象的话将会导致伊甸园和两个survior区大量的内存拷贝。
  3. 对象不一定要达到年龄才进入老年代,虚拟机有一个动态年龄的概念,如果Survior空间中所有相同年龄大小的总和大于Survivor空间的一半,那么年龄大于等于该年龄的对象就可以直接进老年代。

触发条件(Minor GC、Full GC)

新生代(Minor GC)触发条件:伊甸园空间不足,就会进行Minor GC回收新生代

老年代(Full GC)触发条件:

  1. 老年代空间不足;
  2. 元空间不足;
  3. 要晋升老年代的对象所占用的空间大于老年代的剩余空间;
  4. 显式调用System.gc();
  5. 建议垃圾回收器执行垃圾回收:-XX: +DisableExplicitGC 参数,忽略掉System.gc()的调用;
相关推荐
中國龍在廣州31 分钟前
35天,成了AI 模型的斩杀线
大数据·人工智能·深度学习·算法·机器人
Albert Edison32 分钟前
【ProtoBuf】初识 protobuf
java·开发语言·protobuf
码出财富9 小时前
SpringBoot 内置的 20 个高效工具类
java·spring boot·spring cloud·java-ee
多米Domi0119 小时前
0x3f第33天复习 (16;45-18:00)
数据结构·python·算法·leetcode·链表
我是小疯子669 小时前
Python变量赋值陷阱:浅拷贝VS深拷贝
java·服务器·数据库
森叶9 小时前
Java 比 Python 高性能的原因:重点在高并发方面
java·开发语言·python
二哈喇子!9 小时前
Eclipse中导入外部jar包
java·eclipse·jar
微露清风9 小时前
系统性学习C++-第二十二讲-C++11
java·c++·学习
罗湖老棍子9 小时前
【例4-11】最短网络(agrinet)(信息学奥赛一本通- P1350)
算法·图论·kruskal·prim
方圆工作室9 小时前
【C语言图形学】用*号绘制完美圆的三种算法详解与实现【AI】
c语言·开发语言·算法