《剑指JVM》——第16章——垃圾收集器的分类——垃圾收集器2

🌈hello,你好鸭,我是Ethan,西安电子科技大学大三在读,很高兴你能来阅读。

✔️目前博客主要更新Java系列、项目案例、计算机必学四件套等。
🏃人生之义,在于追求,不在成败,勤通大道。加油呀!

🔥个人主页:Ethan Yankang
🔥推荐:史上最强八股文||一分钟看完我的几百篇博客

🔥温馨提示:划到文末发现专栏彩蛋   点击这里直接传送

🔥本篇概览:详细讲解了垃圾收集器的分类分区域(新生代、老年代、整堆)、压缩式与非压缩式、串行、并行、并发——垃圾收集器2🌈⭕🔥


【计算机领域一切迷惑的源头都是基本概念的模糊,算法除外】


🔥 《剑指JVM》序言-CSDN博客

🔥 《剑指JVM》全书-CSDN博客


🌈章节引出

前一篇章:《剑指JVM》——第16章——垃圾收集器的性能指标——垃圾收集器1-CSDN博客

🌈章节速览


一、垃圾收集器的分类#


分区域(新生代、老年代、整堆)

        首先,在本书 7.3节提到 Java 堆分为新生代和老年代,生命周期较短的对象一般放在新生代,生命周期较长的对象会进入老年代。不同区域的对象,采取不同的收集方式,以便提高回收效率。因此根据垃圾收集器工作的内存区间不同,可分为新生代垃圾收集器,老年代垃圾收集器和整堆垃圾收集器,如图 :


新生代收集器:        Serial、ParNew、Parallel Scavenge。
老年代收集器:        SerialOld、Parallel Old、CMS。
整堆收集器:        G1。

        其次,新生代在每次垃圾收集发生时,大部分对象会被回收,存活对象数量较少,因此每次回收进行碎片整理是非常高效的。而老年代的每次回收,存活对象数量较多,复制算法明显变得不合适,一般选用标记-清除算法,或者标记-清除算法与标记-压缩-算法混合实现。

压缩式与非压缩式

        因此垃圾收集器可分为压缩式垃圾收集器和非压缩式垃圾收集器。压缩式垃圾收集器会在回收完成后,对存活对象进行压缩整理,消除回收后的碎片,如果再次分配对象空间,使用指针碰撞技术实现,比如 Serial Old 就是压缩式垃圾收集器。非压缩式垃圾收集器不进行这步操作,如果再分配对象空间,只能使用空闲列表技术实现,比如CMS就是非压缩式垃圾收集器。

        最后,垃圾收集器还可以分为串行垃圾收集器、并行垃圾收集器、并发式垃圾收集器等。这又是怎么回事呢?要弄清楚这些,我们需要先来看一下在操作系统中串行(Serial)、并行(Parallel)和并发(Concurrent)的概念。


    串行、并行、并发

            串行垃圾收集器是指使用单线程收集垃圾,即使存在多个CPU可用,也只能用一个执行垃圾回收,所以应用程序一定会发生 STW。使用串行方式的垃圾收集器有 Serial 等

        并行垃圾收集器指使用多个垃圾收集线程并行工作,当多个CPU可用时,并行垃圾收集器会使用多个CPU同时进行垃圾回收,因此提升了应用的吞吐量,但此时用户线程仍会处于等待状态,即STW现象仍然会发生。使用并行方式的垃圾收集器有ParNew、Parallel Scavenge、Parallel Old等。

        并发垃圾收集器是指用户线程与垃圾收集线程“同时”,但此时用户线程和垃圾收集线程不一定是并行的,可能会交替执行。如果此时存在多个CPU或者一个CPU存在多核的情况,垃圾收集线程在执行时尽可能减少“停顿”用户程序的运行,即垃圾收集线程不会独占CPU资源,用户程序再继续运行,而垃圾收集程序线程运行于另一个CPU上。使用并发方式的垃圾收集器有CMS和G1。


二、查看默认的垃圾回收器 


查看默认的垃圾收集器可以参考下面的方式:
(1)-XX:+PrintCommandLineFlags:查看命令行相关参数(包含使用的垃圾收集器)。
(2)使用命令行指令:“jinfo -flag 相关垃圾收集器参数 进程 ID”。

下面我们使用第一种实际编码来看看:

编码:

package com.itheima;

/**
 * Hello world!
 *
 */
public class App 
{
    public static void main( String[] args ) throws InterruptedException {
        System.err.println( "Hello World!" );
        byte[] bytes=new byte[10*1024*1024];//10M
        bytes=null;
        System.gc();

        Thread.sleep(1000000);
    }
}

JDK8

验证JDK8的垃圾回收器:

 

程序运行如下:

使用命令

jinfo -flag UseParallelGC PID
jinfo -flag UseG1GC PID

来查看具体的参数:

可以看到JDK8中的垃圾回收器是并行垃圾回收器,而G1没有被开启。(前面是-)


JDK21

验证JDK21的垃圾回收器:

具体结果如下

使用命令

jinfo -flag UseParallelGC PID
jinfo -flag UseG1GC PID

来查看具体的参数:

可以看到JDK21中的垃圾回收器是G1垃圾回收器,而并行垃圾回收器没有被开启。(前面是-)



💖💖💖💖💖💖💖💖💖💖💖💖💖💖💖💖💖💖

热门专栏推荐

🌈🌈计算机科学入门系列                     关注走一波💕💕

🌈🌈CSAPP深入理解计算机原理        关注走一波💕💕

🌈🌈微服务项目之黑马头条                 关注走一波💕💕

🌈🌈redis深度项目之黑马点评            关注走一波💕💕

🌈🌈JAVA面试八股文系列专栏           关注走一波💕💕

🌈🌈JAVA基础试题集精讲                  关注走一波💕💕   

🌈🌈代码随想录精讲200题                  关注走一波💕💕


总栏

🌈🌈JAVA基础要夯牢                         关注走一波💕💕  

🌈🌈​​​​​​JAVA后端技术栈                          关注走一波💕💕  

🌈🌈JAVA面试八股文​​​​​​                          关注走一波💕💕  

🌈🌈JAVA项目(含源码深度剖析)    关注走一波💕💕  

🌈🌈计算机四件套                               关注走一波💕💕  

🌈🌈数据结构与算法                           ​关注走一波💕💕  

🌈🌈必知必会工具集                           关注走一波💕💕

🌈🌈书籍网课笔记汇总                       关注走一波💕💕         



📣非常感谢你阅读到这里,如果这篇文章对你有帮助,希望能留下你的点赞👍 关注❤收藏✅ 评论💬,大佬三连必回哦!thanks!!!
📚愿大家都能学有所得,功不唐捐!

  • 19
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值