JAVA JVM 垃圾收集器

垃圾收集算法

  1. 标记清除法
  2. 复制法
  3. 标记整理法
  4. 分代收集法

缺点

  1. 标记清除法:
    原理: 从根开始扫描,标记所有的存活对象(可达对象),然后对所有未标记的对象进行清除操作。
    缺点: 清除后会产生不连续内存,内存碎片,导致资源浪费。
  2. 复制法:
    原理: 把一块区域切分成2份,从s1把所有存活对象进行复制到s2区域,然后把s1的清除。
    缺点: 资源分为2块,运行时只使用一份区域,另一个区域空闲,导致资源浪费。
  3. 标记整理法:
    原理: 扫描标记与标记清除法一样,但是他在清除前还有一步,整理步骤。首先对存活对象进行标记,然后对标记对像向一端进行移动整理,然后清除另一端。
    缺点: 步骤添加,所以性能消耗会大

分代收集法

分为年轻代,老年代。
年轻代:垃圾回收时都会对很大一部分对象进行回收,所以内存占用比较小,而且gc频率会略高。一般会使用复制法。
老年代:垃圾回收时,一般都是较小的进行回收,因为到老年代的对象,一般都是默认经过15次回收才到老年代,所以大部分都是使用中。一般会使用标记清除或标记整理法。

垃圾回收器产品

  1. serial 使用在年轻代,串行gc
  2. ParNew 使用在年轻代,并行gc
  3. Parallel Scavenge 使用在年轻代,并行gc
  4. serial old 使用在老年代,串行gc
  5. parallel old 使用在老年代,并行gc
  6. cms 使用在老年代,并发gc(据说能做还可以设置还精准stw的时间)

serial会与serial old或cms搭配使用
parnew会与serial old 或cms搭配使用
parallel scavenge会与parallel old搭配使用

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值