01-2 JVM-堆与垃圾回收算法

系列文章目录

01-1 JVM-线程与内存区域
01-2 JVM-堆与垃圾回收算法



一、堆

堆从GC的角度还可以细分为:新生代区和老年代区。其中新生代还可以细分为Eden区、From Survivor区和To Survivor区,两个幸存者区也可以称为S1区和S2区。
在这里插入图片描述

1.新生代区

用来存放新生的对象。一般占据堆的1/3空间。由于频繁创建对象,所以新生代会频繁出发MinorGC进行垃圾回收。

1.1 Eden区

Java新对象的出生地(如果对象占用内存很大,则直接分配到老年代)。Eden区内存不够时会触发一次MinorGC。

1.2 S1区和S2区

分别轮流作为上一次GC的幸存者与被扫描者。

1.3 MinorGC采用复制算法

在这里插入图片描述

2.老年代

主要存放生命周期长的内存对象。
老年代的对象比较稳定,不会频繁执行MajorGC。在MajorGC之前会进行一次MinorGC,或者当无法找到足够大的连续空间分配给新创建的较大对象时也会提前触发一次MajorGC。
MajorGC采用标记清除算法

3.永久代

主要存放Class和Meta的信息。GC不会在主程序运行时期对永久代进行清理。所以永久代可能因为Class的增多而发生OOM异常。

3.1 Java8与元数据

Java8中,永久代已经被移除,取而代之的是一个叫“元空间”的区域。元空间和永久代类似,元空间与永久代之间最大的区别在于:元空间并不在虚拟机中,而是使用本地内存。类的元数据访日native memory,字符串池和类的静态变量放入java堆中。元数据不再由MaxPermSize控制。


二、垃圾回收算法

在这里插入图片描述

1.垃圾搜索算法

1.1引用计数法

根据一个对象是否还存在引用判断一个对象是否可以回收。若某个对象的引用计数为0,则说明该对象不大可能再被用到,则该对象是可回收对象。
引用计数法的缺点是可能会存在循环引用的问题,即两个都应该被回收的对象互相引用,导致两者的引用计数都不为0,发生循环引用问题。

1.2可达性分析

为解决引用计数法的循环引用问题,Java使用了可达性分析的方法。通过一系列的“GC roots”对象作为起点搜索
如果GR与一个对象之间没有任何可达路径,则该对象是不可达的。
不可达对象变为可回收对象至少要经过两次标记。

2.垃圾清除算法

2.1标记清除算法(Mark-Sweep)

在这里插入图片描述
两个阶段,标记和清除。
最大的问题是内存碎片化严重。

2.2复制算法(Copying)

在这里插入图片描述
不会产生碎片化问题,但压缩了一半的内存空间。

2.3标记整理算法(Mark-Compact)

在这里插入图片描述
结合了以上两个算法。

2.4分代收集算法

根据不同区域选择不同的算法。

2.4.1新生代与复制算法

在这里插入图片描述
不按照1:1划分内存空间,一般按照8:1:1的比例划分。

2.4.1老年代与MC算法

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值