JVM垃圾收集器总结
前言:
了解了JVM垃圾回收算法之后就要说说垃圾收集器了。
一、三个概念
Stop-the-World:JVM执行任何一种GC算法时是会停止应用程序的执行的,所以大多数GC优化都是从减少Stop-the-world发生的时间来提高程序性能。
SafePoint:安全点。在JVM进行可达性分析的时候要在安全点进行,这个点是所有线程都被冻结,避免出现分析过程中对象的引用关系还在不断变化。前面说的程序停止不是随便停止,而是到达安全点之后再停顿下来。产生安全点的地方有:方法调用,循环跳转,异常跳转等
二、年轻代区的垃圾收集器
1、Serial收集器
单线程收集器,进行垃圾收集的时候必须暂停其他所有工作线程,直到收集结束。对于运行在client模式下的虚拟机是个很好的选择。可以通过设置-XX:+UseSerialGC进行使用,使用的是复制算法回收。
2、ParNew收集器
使用多条线程进行垃圾收集,其余行为和Serial收集器一样,可以和CMS收集器配合工作。可以通过设置-XX:+UseParNewGC进行使用,一般使用在server模式下。使用的是复制算法回收。
3、Parallel Scavenger收集器
前面两个收集器在于关注用户线程停顿时间,而这个收集器关注点在于达到一个可控的吞吐量【吞吐量=运行用户代码时间/(运行用户代码时间+垃圾收集时间)】,适合在后台运算不需要太多交互的任务。可以通过设置-XX:+UseParallelGC进行使用,是在server模式下的默认收集器。使用的是复制算法回收。
三、老年代区的垃圾收集器
1、Serial Old收集器
单线程收集器,进行垃圾收集的时候必须暂停其他所有工作线程,直到收集结束。client模式下的虚拟机默认的老年代收集器。可以通过设置-XX:+UseSerialOldGC进行使用,使用的是标记-整理算法回收。
2、Parallel Old收集器
配合年轻代为Parallel Scavenger收集器使用的,行为都与Parallel Scavenger收集器差不多只是算法不一样。同样适合在后台运算不需要太多交互的任务。可以通过设置-XX:+UseParallelOldGC进行使用。使用的是标记-整理算法回收。
3、CMS收集器
是一种以获取最短回收停顿时间为目标的收集器,可以通过设置-XX:+UseConcMarkSweepGC进行使用。基于标记-清除算法。运动过程有6个步骤:
初始标记:需要虚拟机进行stop-the-world,仅标记一下GC Roots所能连接到的对象
并发标记:进行GC Roots 追踪的过程,这时候程序不会停顿
并发预清理:查找执行并发标记阶段从年轻代进入老年代的对象。
重新标记:进行stop-the-world,扫描CMS堆中的剩余对象
并发清除:清理垃圾对象,程序不会停顿
并发重置:重置CMS收集器的数据结构
使用这个收集器使得用户进程能在运行的时候进行清理垃圾对象。在清理过程中产生的垃圾对象会由下一次再回收。但是由于使用的是标记-清除算法,容易使得内存碎片化。
4、G1收集器
这是一个既用于年轻代也用于老年代的收集器。使用G1收集器时Java堆就会与使用其他收集器的布局不同。它是将整个Java堆内存划分为多个大小相等的Region,这样年轻代和老年代就不再物理隔离。
可以通过设置-XX:+UseG1GC进行使用,使用的是复制+标记-整理算法回收。这样就不会出现内存碎片化。
具备如下特点:
并行与并发,使用多个CPU来缩短stop-the-world的停顿时间,这样在GC的时候不需要停顿Java线程。使得GC和用户线程并发执行。
分代收集:G1是存在于年轻代和老年代的收集器。年轻代使用负责算法,老年代使用收集器。
空间整合。是基于标记-整理的算法实现的。可以解决内存碎片的问题。
可预测的停顿。能让使用者明确指定在一个长度为M毫秒的时间片段内。
总结
这个其实只是针对不同场景进行选择收集器,只需要了解收集器适用的场景和作用。具体的算法之前已经介绍过。
JVM垃圾收集器总结的更多相关文章
- JVM调优:HotSpot JVM垃圾收集器
HotSpot JVM垃圾收集器 - Snooper - 博客园https://www.cnblogs.com/snooper/p/8718478.html
- JVM垃圾收集器-Parallel Scavenge收集器
今天我给大家讲讲JVM垃圾收集器-Parallel Scavenge收集器 Parallel Scavenge收集器 Parallel Scavenge收集器也是一个新生代收集器,它也是使用复制算法的 ...
- 7种JVM垃圾收集器特点,优劣势、及使用场景
今天继续JVM的垃圾回收器详解,如果说垃圾收集算法是JVM内存回收的方法论,那么垃圾收集器就是内存回收的具体实现. 一.常见的垃圾收集器有3类 1.新生代的收集器包括 Serial PraNew Pa ...
- 【006】【JVM——垃圾收集器总结】
Java虚拟机学习总结文件夹 JVM--垃圾收集器总结 垃圾收集器概览 收集算法是内存回收的方法论.垃圾收集据是内存回收的详细实现.Java虚拟机规范中对垃圾收集器应该怎样实现没有规定.不同的厂 ...
- 第五章 JVM垃圾收集器(1)
说明:垃圾回收算法是理论,垃圾收集器是回收算法的实现,关于回收算法,见<第四章 JVM垃圾回收算法> 1.七种垃圾收集器 Serial(串行GC)-- 复制 ParNew(并行GC)-- ...
- 第六章 JVM垃圾收集器(2)
上一章记录了几种常见的垃圾收集器,见<第五章 JVM垃圾收集器(1)> 1.G1 说明: 从上图来看,G1与CMS相比,仅在最后的"筛选回收"部分不同(CMS是并发清除 ...
- JVM垃圾收集器(1)
此文已由作者赵计刚薪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 说明:垃圾回收算法是理论,垃圾收集器是回收算法的实现,关于回收算法,见<第四章 JVM垃圾回收算法& ...
- 5种JVM垃圾收集器特点和8种JVM内存溢出原因
先来看看5种JVM垃圾收集器特点 一.常见垃圾收集器 现在常见的垃圾收集器有如下几种: 新生代收集器: Serial ParNew Parallel Scavenge 老年代收集器: Serial O ...
- 7种 JVM 垃圾收集器特点、优劣势及使用场景(多图)
7种 JVM 垃圾收集器特点.优劣势及使用场景(多图) mp.weixin.qq.com 点击上方"IT牧场",选择"设为星标"技术干货每日送达! 一.常见垃 ...
- JVM垃圾收集器
JVM中垃圾的回收由垃圾收集器进行,随着JDK的不断升级,垃圾收集器也开发出了各种版本,垃圾收集器不断优化的动力,就是为了实现更短的停顿. 下面是7种不同的分代收集器,如果两个收集器之间有连线,则表示 ...
随机推荐
- puppet多环境配置(puppet自动化系列2)
三.Puppet多环境部署 我们为puppetmaster建立3个环境,它们分别是开发环境(jqdev).测试环境(jqtest).生产环境(jqprd). 3.1 配置puppet.conf 在标签 ...
- Spark Streaming之六:Transformations 普通的转换操作
与RDD类似,DStream也提供了自己的一系列操作方法,这些操作可以分成四类: Transformations 普通的转换操作 Window Operations 窗口转换操作 Join Opera ...
- oracle--循环PL/SQL--demo1---
--简单的条件判断if–then --编写一个过程,可以输入一个雇员名,如果该雇员的工资低于2000,就给该员工工资增加10%. create or replace procedure sp_pro6 ...
- PWA PSI statusingclient.UpdateStatus更新任务页面的AssnCustomFields的TextValue值
1.注意Changesxml格式和下面一定要一样 2.CustomFieldGuid和CustomFieldName都不能少,自定义域的uid和name其中uid或者是MD_PROP_UID_SECO ...
- 使用union来遍历结构体中的成员
前几天和实验室的同学讨论问题的时候发现他使用的一段数据校验的代码自己以前没有接触过,今天有空就把它整理了一下. #include <stdio.h> #include <stdlib ...
- 核PCA与PCA的精髓和核函数的映射实质
1.PCA简介 遭遇维度危机的时候,进行特征选择有两种方法,即特征选择和特征抽取.特征选择即经过某种法则直接扔掉某些特征,特征抽取即利用映射的方法,将高维度的样本映射至低维度.PCA(或者K-L变换) ...
- 菜鸟攻城狮3(Holle World)
1.创建一个HolleWorld.java文本文件 2.代码:public class HolleWorld { public static void main(String[] args) { Sy ...
- Angular14 Angular相关命令
1 创建相关 1.1 创建项目 ng new 项目名 -> 创建新项目 ng new 项目名 --skip-install -> 不进行模块安装 ng new 项目名 -si ng ...
- Learning Python 009 dict(字典)和 set
Python dict(字典)和 set dict (字典)是什么东西 dict全称dictionary.为什么这个数据结构取名叫dict.因为dict的实现原理和查字典是一样的.dict使用了键-值 ...
- p1197&bzoj1015 星球大战
传送门(洛谷) 传送门(bzoj) 题目 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系.某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器,并攻下了星系中几乎所有的 ...