JVM 学习笔记 (六) 垃圾收集器(Garbage Collector)

垃圾收集器

垃圾收集器是内存管理工具,也就是垃圾回收的具体实现。

Serial 收集器

Serial 垃圾收集器是最基本的垃圾收集器,它是单线程的收集器。单线程的意思是,它进行垃圾回收时必须暂停其他所有的工作线程,直到它收集结束。
在服务器环境中使用它体验感很不好,想一下用户访问网站。。结果垃圾收集一下暂停一下。。。。
但它是虚拟机运行在Client模式下的默认新生代收集器,因为桌面应用新生代内存不会太大,停顿时间可以控制一百毫秒以内,只要不是频繁发生,还是可以接受的。

Serial Old 收集器

Serial Old 是 Serial 的老年代版本。它也是单线程收集器。使用标记整理算法。主要也是给Client 模式下的虚拟机使用。

ParNew 收集器

ParNew 收集器是 Serial 收集器的多线程版本,其他与Serial 收集器没有什么太大的区别。它是Server模式下的虚拟机中首选的新生代收集器。

Parallel Scavenge 收集器

Parallel Scavenge 收集器是一个新生代收集器,它也是使用复制算法的收集器,也是并行的多线程收集器。
Parallel Scavenge 收集器的目标是达到一个可控制的吞吐量。
吞吐量=运行代码时间/(运行代码时间+垃圾收集时间)

Parallel Old 收集器

Parallel Old 是 Parallel Scavenge 收集器的老年代版本,使用多线程和标记整理算法。

CMS(Concurrent Mark Sweep)收集器

CMS 是一种以获得最短回收停顿时间为目标的收集器。CMS是基于标记清除算法来实现的。

G1(Garbage-First)收集器

G1是一款面向服务端应用的垃圾收集器。
G1 将整个java堆划分为多个大小相等的独立区域,有计划的避免进行全区域的垃圾回收。G1跟踪各个区域的垃圾堆积的价值大小(回收所获得的空间大小以及回收所需要时间的经验值),维护 一个优先列表,每次根据允许的收集时间,优先回收价值最大的区域。

暂时简单了解一下,后面再去深入了解垃圾收集器。

参考资料

学习摘抄于深入理解Java虚拟机

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值