首先需要了解下JVM(Java虚拟机)中的内存分配情况:

收集器的介绍

Serial收集器:是最原始的收集器,是单线程的,实现简单,但是在后台收集垃圾的时候,其他的工作线程都会停止,直到垃圾收集线程执行完毕,给用户的体验就是出现停顿现象,体验差。但是当收集的垃圾少,停顿时间短,次数少,还是可以接受的。运行在Client模式下是一个很好的选择。
ParNew收集器:是Serial收集器的多线程办,不过在单处理器下效果不比Serial收集器效果好,多线程会采取对应的机制,默认开始的线程数量和CPU的数量相同。
CMS收集器:目标是缩短用户的停顿时间,即垃圾收集的时间,是并发收集器,是牺牲吞吐量和新生代空间来换取的。
Parallel Scavenge收集器:目标是达到一个可控的吞吐量(运行用户代码/(运行用户代码+垃圾收集时间)),被称为吞吐量优先的收集器。采用复制算法实现

算法

引用计数法:在对象中添加一个基数器,当有变量引用这个对象时,计数器就加一,当变量放开对这个对象的引用时,计数器就减一,当计数器的值为0时,表示没有引用这个对象的变量了,后续就可以被垃圾收集器处理了。
优缺点:实现简单,但针对互相引用的对象没办法进行清理。如:      objA.instance=objB;objB.instance=objA;这种情况下,其他变量引用这2个对象了,但是这两个   对象仍然不能删除,因为它们互相引用,计数器的值不为0.

可达性分析:以GC Roots为起点,从这些节点开始,向下搜索形成引用链,当GC Roots到某个对象为不可达时,表示这个对象就是一个无用的对象,可以在垃圾收集时进行处理。
标记-清处算法:进行2个过程,标记:把需要清理的对象都标记出来;清除:就是把标记的对象都清楚掉。这2个过程效率都不是很高,且会产生很多空间碎片,导致因为大对象没有连续的内存分配空间而引起再次的垃圾回收。

复制算法:标记-清除算法中存在效率和空间碎片问题,此复制算法可以解决效率问题,把内存空间分为等同大小的块,使用其中的一块进程分配,当内存用完时,把还存活的对象放到另一个内存中,然后把原理内存块一起清理掉,新块中根据指针按需分配排列。实现简单,效率好,但是会浪费一般的内存。
标记整理算法:此算法也是分为2步,第一步标记,第二步整理,标记和前面讲的标记一样,仅是第二步整理,是把存活的对象往一个方向移动,然后清除掉边缘部分。此种算法没有空间碎片的存在了。
分代收集算法:没有采用新的算法,而是根据对象的存活时间不同,把内存分为新生代和老年代,且由于新生代多为新创建的对象,需要的内存空间大,比例按照8:1:1进行划分内存的。然后根据区域的不同采用不同的收集算法,新生代的对象存活率低,可以使用复制算法,老年代的对象存活率高,可以采用标记清除或者标记整理算法。

GC日志

GC的日志格式就是时间+类型+内存数据等信息的构成
在日志结果中,可以观察到,使用的收集器是Parallel Scavenge收集器-> PSYoungGen,ps是缩写,默认的Default New Generation的是新生代是使用Serial收集器。名字与收集器有关。使用时根据具体的情况进行实例对象的分配,比如新生代中的Eden区内存不够时,接下来大的实例化对象存到survivor中也不够,则就会直接存储到老年区。

而使用Serial收集器时,先分配6M的新生代区域,后面的4M不够分配,会发生minor GC,在GC期间,6M的空间不足以分配到survivor区域(这个区域仅1M),所以会通过担保机制把6M的对象直接放入到老年区。使用的收集器不同得出的垃圾回收日志会不相同。
Minor GC:是指新生代的垃圾回收,一般java对象的生命周期都很短,minor GC频繁,回收也快。
Full GC:指老年代的回收,经常会伴随一次minor GC,但不是绝对的,Parallel Scavenge就可以直接Major GC,速度一般比minor GC 慢10倍以上。

测试代码如下所示:

package com.class01;

/**
* @Author: guopengxia
* @Date: 2019/3/22 19:09
* @Version: 1.0
*/
public class Class01 {
private static final int _1MB=1024*1024;
/**
* 设置VM的参数:
* -Xms20M -Xmx20M -Xmn10M //Xms,Xmx设置堆内存的大小(20M) Xmn:设置年轻代大小
* -XX:PrintGCDetails //设置打印GC的详细信息(收集器日志参数)
* -XX:SurvivorRatio=8 //设置老年区的比例信息,新生区Eden:其中一个Survivor的比例为8:1
*/ public static void testAllocation(){
byte [] allocation1,allocation2,allocation3,allocation4;
allocation1=new byte[2*_1MB];
allocation2=new byte[2*_1MB];
allocation3=new byte[2*_1MB];
allocation4=new byte[4*_1MB]; //此处会出现一次Minor GC(当新生代没有内存进行分配时,会出现Minor GC)
} public static void main(String []args){
Class01.testAllocation();
}
}

下面是日志截图,这次是日志显示到控制台(可以把GC的信息打印到日志文件中,进行参数设置即可)

JVM中的垃圾回收器及垃圾收集算法描述的更多相关文章

  1. jvm中的垃圾回收器

    HotSpot JVM收集器 上面有7中收集器,分为两块,上面为新生代收集器,下面是老年代收集器.如果两个收集器之间存在连线,就说明它们可以搭配使用.Serial(串行GC)收集器 Serial收集器 ...

  2. JVM学习--(五)垃圾回收器

    上一篇我们介绍了常见的垃圾回收算法,不同的算法各有各的优缺点,在JVM中并不是单纯的使用某一种算法进行垃圾回收,而是将不同的垃圾回收算法包装在不同的垃圾回收器当中,用户可以根据自身的需求,使用不同的垃 ...

  3. JVM有哪些垃圾回收器

    JVM 的垃圾回收器 目录 JVM 的垃圾回收器 经典垃圾收集器 Serial 收集器 ParNew 收集器 Parallel Scavenge 收集器 Serial Old 收集器 Parallel ...

  4. JVM学习——G1垃圾回收器(学习过程)

    JVM学习--G1垃圾回收器 把这个跨时代的垃圾回收器的笔记独立出来. 新生代:适用复制算法 老年代:适用标记清除.标记整理算法 二娃本来看G1的时候觉得比较枯燥,但是后来总结完之后告诉我说,一定要慢 ...

  5. 浅谈jvm中的垃圾回收策略

    下面小编就为大家带来一篇浅谈jvm中的垃圾回收策略.小编觉得挺不错的,现在就分享给大家,也给大家做个参考.一起跟随小编过来看看吧   java和C#中的内存的分配和释放都是由虚拟机自动管理的,此前我已 ...

  6. java面试一日一题:java中的垃圾回收器

    问题:请讲下java中垃圾回收器有哪些? 分析:该问题主要考察hotspot虚拟机下实现的垃圾回收器 回答要点: 主要从以下几点去考虑, 1.垃圾回收器的种类 2.每种垃圾回收器的着重点是什么 前边的 ...

  7. 说一下 jvm 有哪些垃圾回收器?

    新生代收集器: SerialParNewParallel Scavenge 老年代收集器: Serial OldCMSParallel Old 堆内存垃圾收集器: G1 参考链接:JVM常见的垃圾回收 ...

  8. JVM几种垃圾回收器介绍

    整理自:http://www.cnblogs.com/lspz/p/6397649.html 一.如何回收? 1.1 垃圾收集算法: (1)标记-清除(Mark-Sweep)算法 这是最基础的算法,就 ...

  9. JVM 中的垃圾回收

    说到JVM,总是绕不开垃圾回收,因为其是JVM的核心之一,因为对象的创建是非常频繁的,想要提高程序的执行效率,拥有一个高效的垃圾回收机制是必不可少的. 首先要明确,因为对象的创建只在堆中,所以垃圾回收 ...

随机推荐

  1. 对比剖析Swarm Kubernetes Marathon编排引擎

    Docker Native Orchestration 基本结构 Docker Engine 1.12 集成了原生的编排引擎,用以替换了之前独立的Docker Swarm项目.Docker原生集群(S ...

  2. centos7多网卡配置bond0 (mode6无需交换机做配置)

    1.执行setup命令-->网络配置-->本例中四块网卡. 2.ifconfig列出四块网卡. 3.我们的目标,绑定eth0和eth1两块网卡作为公网网卡,ip设置为192.168.0.5 ...

  3. Mask rcn nanchor部分理解

    Anchors Mask 生成锚框本质与SSD一样中心点个数等于特征层像素数框体生成围绕中心点Bbox的坐标是要归一化到0~1之间的,都是相对于输入图片的大小.基本生成方式:H乘np.sqrt(anc ...

  4. html5中视频播放问题总结

    html5中视频播放问题总结 文章 1.问题一 框架? 加个标签就OK! <video id="video1" src="/video1.mp4" con ...

  5. 读取本地json文件,并转换为dictionary

    // 读取本地JSON文件 - (NSDictionary *)readLocalFileWithName:(NSString *)name { // 获取文件路径 NSString *path = ...

  6. CH 5102Mobile Service题解

    题目: 用动态规划很容易将完成任务量作为dp的阶段,通过指派服务员,从当前i-1个任务转移到i个任务: 我们可以用一个四维数组f[i][x][y][z]来表示在完成当前任务i时,三个机器人分别在x,y ...

  7. loj 6008 餐巾计划 - 费用流

    题目传送门 传送门 题目大意 (经典题还不知道题意?) 容易想到需要把未使用的餐巾和已经使用的餐巾分开. 设$X_i$表示第$i$天已经的使用餐巾的点,设$Y_i$表示第$i$天还未使用的餐巾的点 我 ...

  8. python爬取全名k歌

    python3 爬取全名k歌 代码: import re import requests import ssl ssl._create_default_https_context=ssl._creat ...

  9. RsaUtils

    参考来源:https://www.cnblogs.com/pcheng/p/9629621.html 里面的这段话,非常好 RSA加密对明文的长度有所限制,规定需加密的明文最大长度=密钥长度-11(单 ...

  10. 使用TLS证书保护Docker

    使用TLS证书保护Docker 当我们使用远程调用docker时,未设置TLS的docker,将可以被任何人调用,这是极其危险的. 在阿里云上跑的docker,这次就被不怀好意的人扫描到了默认端口,2 ...