jvm 垃圾回收器比较_jvm有哪些垃圾回收算法

jvm 垃圾回收器比较_jvm有哪些垃圾回收算法十种垃圾回收器的简介以及调优的一些经验

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

回顾


什么是GC?

找到垃圾,并且回收,让这块内存重新可用。

Java的GC算法是根搜索算法,可以作为GCRoot的对象有

  • 线程栈变量
  • 静态变量
  • 常量池
  • JNI指针

回收的算法有:

  • 标记清除
  • 标记整理
  • 复制算法
    TLAB:Thread Local Allocation Buffer

回收器简介


垃圾回收器的发展过程是随着内存越来越大的过程而演进的。
从分代算法演化到不分代算法。
十种垃圾回收器

分代算法的垃圾回收器

Young 年轻代收集器
  1. Serial
    单线程垃圾回收器,在回收时会STW(Stop-The-World:其他所有的工作线程都停止,只有垃圾回收线程在工作)
    Serial在内存小(几兆到几十兆)的时候STW时间短,但随着内存的增大,STW的时间变长。
    Serial收集器

  2. ParNew
    Parallel Scavenge的增强,区别点是ParNew能和CMS搭配

  3. Parallel Scavenge
    多个GC线程,在回收时依然会STW。
    适用于几个G的内存。
    Parallel Scavenge 垃圾回收器

Old 老年代收集器
  1. CMS
    Concurrent Mark Swap 并发标记清除,承前启后的算法,但有缺点,没有一个JDK版本默认使用CMS。

    三色标记 – 错标 – Incremental Update增量更新 – Remark + 写屏障

    CMS缺点:Mark&Swap会使空间不连续,当新的对象不能从新生代升级到老年代的时候,它会使用单线程(Serial Old)对老年代进行清理 ,大内存是不能容忍的。
    适用于几十个G的内存。
    CMS
    CMS有两次STW,但都很短暂。
    初始标记只标记GC Root,并发标记从GC Root向下搜索。

    问题

    • 并发标记为非垃圾,在标记之后工作线程又把它设为垃圾。这就会造成浮动垃圾
    • 并发标记为垃圾,但在标记之后工作线程又重新连接了它。这问题如果不解决会造成非常严重的问题。

    并发标记会有一些失误重新标记会修正这些失误。

  2. Serial Old
    老年代的Serial

  3. Parallel Old
    老年代的Parallel

常用的组合:

  • Serial 和 Serial Old,现在已经很少见了。
  • Parallel Scavenge 和 Parallel Old , 1.8版本默认的搭配,简称PS+PO或Parallel GC
  • ParNew 和 CMS

不使用分代算法的垃圾回收器

  1. G1
    Garbage First:分区(Region)回收,优先清理垃圾最多的区。逻辑上每个区可以是Old,Survior,Eden,Humongous,物理上不分代,但是逻辑上依然是分代算法。
    支持上百个G的内存。

    三色标记 + SATB + 写屏障

G1垃圾回收器

  1. ZGC
    不分代。

    Colored Pointer颜色指针 着色指针 + 读屏障

    支持4个T的内存。

  2. Shenandoah
    算法与ZGC类似,与ZGC是竞争关系。
    支持4个T的内存。

  3. Epsilon
    啥也不干的垃圾回收器,可以用来:

    • 确认一个程序根本不需要用GC,可以用Epsilon
    • 程序测试,用来观察垃圾产生的过程。

调优


基础概念:

  1. 吞吐量 :用户代码时间/(用户代码时间 + 垃圾回收时间)
  2. 响应时间 :STW时间越短,响应时间越好。

对于科学计算、数据挖掘,优先考虑吞吐量。
对于网站、GUI优先考虑响应时间。

什么是调优?

  1. 根据需求,对JVM规划和预调优
  2. 优化JVM运行环境(卡顿、慢)
  3. 解决JVM运行过程中出现的问题(OOM)

命令行参数介绍
HotSpot参数分类:

标准: – 开头
非标准: -X开头,特定版本的HotSpot支持特定的命令
不稳定: -XX开头,下个版本可能取消

命令行参数大全

java -XX:+PrintFlagsWithComments  # 只有Debug版本能用

待续…

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/197772.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 兄弟连新版Linux视频教程

    兄弟连新版Linux视频教程兄弟连新版Linux视频教程目录:F:\linux\兄弟连新版Linux视频教程├(1)云计算是什么东西集群又是嘛玩意?.mp4├(2)兄弟连新版Linux教程1.1.1Linux系统简介-UNIX发展历史和发行版本.mp4├(3)兄弟连新版Linux教程1.1.2Linux系统简介-Linux发展历史和发行版本.mp4├(4)兄弟连新版Linux教程1.2Linux系统简介-开源软件…

    2022年6月10日
    34
  • Vim的终极配置方案,完美的写代码界面! ——.vimrc[通俗易懂]

    Vim的终极配置方案,完美的写代码界面! ——.vimrc[通俗易懂]先秀一下我的Vim界面语法补全我用的是YouCompleteMe,有目录树插件,taglist插件等。通过插件管理器Vundle来进行安装,具体方法自行百度。背景可以通过换张自己喜爱的壁纸,然后调终端的透明度,就可以对着自己喜爱的场景编程啦~有语法高亮,语句补全,显示行号,自动缩进等等功能。还有创建源文件自动添加头文件的功能,例如写一个.c程序自动添加…

    2022年6月14日
    42
  • mybatis逆向生成java代码_mybatis生成

    mybatis逆向生成java代码_mybatis生成前言有时候,我们创建实体类需要跟数据库表里面的字段对应起来。假如一张表有数百个字段,那么手动去写实体类的话就比较麻烦,而且容易出错。解决方案其实解决这个问题的方式有很多,本文介绍其中一种解决方案,通过mybatis的逆向工程生成实体类。本文使用的数据库是Oracle,MySQL只需要修改jar包以及generator.properties配置即可。可以从公众号【程序员高手之路】回复“逆向工程”获取源码!Step1修改p…

    2022年8月21日
    6
  • 炉石传说怎么改服务器(炉石firestone怎么用)

    魔兽世界中,炉石是一个相当关键的道具,因为玩家在深入野外探险以后,如果要原路返回就太耗时间了,因此炉石很重要,那么炉石怎么用呢,下面游戏吧小编为大家带来介绍。魔兽世界炉石怎么用魔兽世界中炉石只需要玩家右键点击炉石就能使用,可以直接在背包里点,或者拖到快捷键上用快捷键点。炉石冷却时间为半个小时,使用炉石需要一定的施法时间,过程中玩家的施法动作像在双手搓东西,因此也叫搓炉石。玩家需要注意的是,炉石传送…

    2022年4月16日
    148
  • roseha linux,RoseHA 9.0 for Linux快速安装说明_v2.0-2015-04.pdf

    roseha linux,RoseHA 9.0 for Linux快速安装说明_v2.0-2015-04.pdfRoseHA9 0forLinux 快速安装说明 v2 0 2015 04RoseHA9 0forLinux 快速安装说明 RoseHA9 0forLinux 快速安装说明 v2 0 2015 04RoseHA9 0forLinux 快速安装说明目录一 部署准备和要求 11 1RoseHA 集群的拓扑结构 11 2 硬件和系统环境准备 11 3 应用服务部署要求 51 4

    2025年9月6日
    4
  • SpringBoot 自动配置原理[通俗易懂]

    SpringBoot 自动配置原理[通俗易懂]创建项目通过SpringInitialize创建SpringBoot项目而接下来要说的是关于配置文件的事情。关乎配置文件可以参考官方文档。对于配置文件来说到底在配置文件里面可以进行配置那些内容,自动配置的原理又是什么东西呢?自动配置原理在SpringBoot启动的时候加载主配置类,开启了自动配置的功能,通过@EnableAutoConfiguration注解开启自动配置的功能。@Im…

    2022年6月17日
    23

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号