JVM--垃圾回收器的相关知识点汇总

1.串行垃圾回收器

从标题我们就可以知道,所谓的串行就是指我们的这个垃圾回收器是单线程的

所谓的单线程就是指当用户到达安全点后,垃圾回收进程进行,此时用户进程会被阻塞,只有垃圾回收线程会运行。

因此串行垃圾回收适用于内存较小,cpu数目较小的,如个人电脑

下面是相关的运行简图

### 吞吐量优先垃圾回收器

特点:

多线程

适用场景:堆内存较大,多核

***注重单位时间内,STW的时间最短***

打个比方就是吞吐量要求我们在1分钟内STW次数少,这样数据的吞吐量就占用的比例就会比较大

-XX:+UseParallelGC ~ -XX:+UseParallelOldGC 

并行垃圾回收(只要开启其中一个,另外一个也会开启)

-XX:+UseAdaptiveSizePolicy   

采用自适应的调整新生代的大小

-XX:GCTimeRatio=ratio

吞吐量的目标 调整垃圾回收的时间和总时间的占比 1/1+ratio 垃圾回收的时间(暂停时间) 不能超过此值

-XX:MaxGCPauseMillis=ms 默认值为200ms

-XX:ParallelGCThreads=n  控制cpu的数目

### 响应时间优先(老年代的垃圾回收器)

**特点:**

**多线程**

**使用场景:堆内存较大,多核cpu,尽可能让单次STW的时间最短**

我们可以这样理解吞吐量垃圾回收器于响应时间优先回收器的侧重点:

打个比方,吞吐量就是你一天内用来玩的次数比较少,但是你每次玩的时间比较多(我就喜欢这种)

而响应时间优先可以认为你每天玩的次数比较多,但是你每次玩的时间比较少。

在这里我们先解释一下并发与并行的区别:

**并发:垃圾回收线程和用户的其他的线程同时进行

并行:垃圾回收线程是同时进行的,但是不允许用户的其他线程进行**

我们在老年代运用的垃圾清理算法是:标记清除或整理算法

从运行图中我们可以发现几个问题:

1. 在并发清理的过程中,其他的用户线程仍然在运行,则会导致产生新的垃圾,我们将此记为浮动垃圾,那么我们该如何清除这些浮动垃圾呢?当然你也可以选择等下一次垃圾回收的时候再清除,就像你洗碗的时候,又有人给你一个碗(或者你当助教作业快改完了,又有人交作业,你可以选择下次再改)那么,作为负责任的助教(像我一样),我们该如何处理呢?

      -XX:CMSInitiatingOccupancyFraction=percent  为那些浮动垃圾设置的CMS的触发时机,这个是我们自己设置的。就相当于一个人交了作业我下次再改,但是我想要是再有10个人交,我就不等下次了。

2. **减小重新标记的压力**

-XX:+CMSScavengeBeforeRemark//用于在重新标记之前将新生代的垃圾回收 减轻我们重新标记的压力

存在的问题:若内存碎片过多,会导致CMS变化为SerialOld,这时垃圾回收的时间会大大增加

转自我的csdn--https://blog.csdn.net/tongmengww

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 垃圾收集基础 Java 语言的一大特点就是可以进行自动垃圾回收处理,而无需开发人员过于关注系统资源,例如内存资源的...
    Austin_Brant阅读 757评论 0 2
  • 许多高级编程语言都带有自动垃圾回收特性,以将程序员从繁琐复杂的内存分配和释放工作中解脱。本文将概述常见的垃圾回收算...
    kelgon阅读 2,070评论 2 52
  • 第一章 概述 G1(Garbage First)垃圾收集器是当今垃圾回收技术最前沿的成果之一。早在JDK7就已加入...
    城市里永远的学习者阅读 1,149评论 0 50
  • 当我想起她们,都是像解方程式一样困难理解没有思绪,就像眼前一团雾气散不开。我总能轻易想起那些过分的地方,如何虚伪或...
    Sharon橙子阅读 218评论 0 0
  • 一见钟情 心动不知如何诉说 钟情不知安置何处 应景街角的不期而遇 恰逢其氛的惊鸿一瞥 念着这平仄平平的音阶 宛如那...
    淼漫光年阅读 310评论 4 14