一、概念

GC,Garbage Collection垃圾回收,主要针对JVM中的堆和方法区,而JVM栈、本地方法栈,程序计数器都是线程私有的,跟随线程生命周期。

二、对象存活判断

1. 引用计数:每个对象有个计数器,多一个引用加1,少一个减1,为0时回收

2. 对象可达性分析:到GC Roots没有任何引用链

三、垃圾回收算法种类,内存回收的方法论

1. 标记-清除算法,标记需要回收的对象,然后清除,会产生内存碎片

2. 复制算法,把内存分为两半,一半用来使用,当需要回收时,把存活的对象复制到另一半,限制了内存空间

3. 标记-整理算法,清除完之后移动碎片

4. 分代回收算法:年轻代使用复制算法,老年代使用标记-整理算法,综合上面几种算法

四、垃圾回收器,内存回收的具体实现

1. 串行收集器(serial collector):

最稳定,效率最高,但应用线程会产生较长停顿,年轻代和老年代都进行单线程串行回收

参数:-XX:+UseSerialGC

2. ParNew收集器:串行收集器的多线程版本,新生代并行,老年代串行

参数:-XX:+UseParNewGC

-XX:ParallelGCThreads 限制线程数量

3. 并行收集器(parallel collector):类似于ParNew收集器

参数:-XX:+UseParallelGC 老年代串行

4. Parallel Old收集器

参数:-XX:+UseParallelGC 老年代并行

5. CMS收集器Concurent Mark Sweep:

a. 以获取最短回收停顿时间为目标,与用户线程一起并发执行,基于标记-清除算法实现

b. 4个步骤:初始标记、并发标记、重新标记、并发清除

c. 参数:-XX:UseConcMarkSweepGC

d. 优缺点:优:并发收集耗时低,缺:产生碎片,并发阶段降低吞吐量

6. G1收集器,重点使用

最新的收集器,弱化新生代和老年代,空间整合(基于标记-整理算法)并可预测停顿

五、 内存申请过程

a. JVM会试图为相关Java对象在Eden中初始化一块内存区域

b. 当Eden空间足够,内存申请结束,否则进行下一步

c. JVM试图释放在Eden中所有不活跃的对象(minor collection),释放后若Eden空间仍然不足,则试图将部分Eden对象放入Survivor区

d. Survivor区被用来作为Eden及old的中间交换区域,当old区空间足够时,Survivor区的对象会被移到old区,否则会被留在Survivor区

e. 当old区空间不够时,JVM进行major collection

f. Full gc后,如果survivor和old区仍然无法存放从Eden复制过来的部分对象,导致JVM无法在Eden区为新对象创建内存,则“out of memory”

六、对象衰老过程

a. 衰老过程:Eden->Survivor Space->Old

b. GC触发条件:YGC:eden空间不足时, FGC:old空间不足,显式调用System.GC时

参考:

http://www.cnblogs.com/ityouknow/p/5614961.html

http://www.cnblogs.com/redcreen/archive/2011/05/04/2037056.html

JVM系列(四):GC策略的更多相关文章

  1. JVM系列二:GC策略&内存申请、对象衰老

    JVM里的GC(Garbage Collection)的算法有很多种,如标记清除收集器,压缩收集器,分代收集器等等,详见HotSpot VM GC 的种类 现在比较常用的是分代收集(generatio ...

  2. 【转载】JVM系列二:GC策略&内存申请、对象衰老

    JVM里的GC(Garbage Collection)的算法有很多种,如标记清除收集器,压缩收集器,分代收集器等等,详见HotSpot VM GC 的种类 现在比较常用的是分代收集(generatio ...

  3. [转]JVM系列二:GC策略&内存申请、对象衰老

    原文地址:http://www.cnblogs.com/redcreen/archive/2011/05/04/2037056.html JVM里的GC(Garbage Collection)的算法有 ...

  4. jvm系列:Java GC 分析

    Java GC就是JVM记录仪,书画了JVM各个分区的表演. 什么是 Java GC Java GC(Garbage Collection,垃圾收集,垃圾回收)机制,是Java与C++/C的主要区别之 ...

  5. jvm系列(四):jvm知识点总结

    原文链接:http://www.cnblogs.com/ityouknow/p/6482464.html jvm 总体梳理 jvm体系总体分四大块: 类的加载机制 jvm内存结构 GC算法 垃圾回收 ...

  6. jvm系列四、jvm知识点总结

    原文链接:http://www.cnblogs.com/ityouknow/p/6482464.html jvm 总体梳理 jvm体系总体分四大块: 类的加载机制 jvm内存结构 GC算法 垃圾回收 ...

  7. JVM 分代GC策略分析

    JVM 分代GC策略分析   我们以Sun HotSpot VM来进行分析,首先应该知道,如果我们没有指定任何GC策略的时候,JVM默认使用的GC策略.Java虚拟机是按照分代的方式来回收垃圾空间,我 ...

  8. jvm系列 (四) ---强、软、弱、虚引用

    java引用 目录 jvm系列(一):jvm内存区域与溢出 jvm系列(二):垃圾收集器与内存分配策略 jvm系列(三):锁的优化 我的博客目录 为什么将引用分为不同的强度 因为我们需要实现这样一种情 ...

  9. java jvm内存管理/gc策略/参数设置

    1. JVM内存管理:深入垃圾收集器与内存分配策略 http://www.iteye.com/topic/802638 Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的高墙,墙外面的人想 ...

  10. 【转】JVM 分代GC策略分析

    我们以Sun HotSpot VM来进行分析,首先应该知道,如果我们没有指定任何GC策略的时候,JVM默认使用的GC策略.Java虚拟机是按照分代的方式来回收垃圾空间,我们应该知道,垃圾回收主要是针对 ...

随机推荐

  1. 坏消息,new Date()方法在IOS系统中存在null值情况

    背景介绍 笔者最近在开发小程序,发现在使用new Date()函数在电脑模拟器上倒是没什么影响能很好实现效果,但是在我的Iphone上看到的效果跟预想有出入. 图为在电脑微信小程序模拟器的效果图,可以 ...

  2. 【linux系统安装】Anolis OS-龙蜥操作系统实机安装流程整理

    [安装准备] 1.准备一个U盘,可储存空间不低于20G,U盘内资料移出去,待会儿要格式化做U盘启动盘 2.windows操作系统上下载"Rufus",官网:http://rufus ...

  3. 副三角形行列式转成上(下)三角形行列式为什么依次对换而不用第n行直接对换首行,第n-1行直接对换次行

    副三角形行列式转成上(下)三角形行列式为什么依次对换而不用第n行直接对换首行,第n-1行直接对换次行 前言:重在记录,可能出错. 1. 简而言之,可以用第n行直接对换首行,第n-1行直接对换次行,直到 ...

  4. 【研究生学习】SNR、Eb/N0和Es/N0的关系

    SNR.Eb/N0与Es/N0的关系 在模拟通信中,SNR是一个非常有用的指标 实例说明

  5. node、mongodb、服务器相关

    1.CentOs搭建NodeJs服务器-Mongodb安装 2.如何将 node+mongodb 项目部署在服务器上 3.如何通过cmd开一个本地服务器 4.如何部署一个本地的web项目到服务器-搭建 ...

  6. 你到底懂不懂JavaScript?来做做这12道面试题试试!

    携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第 21 天,点击查看活动详情 JavaScript 是每一个前端开发者都应该掌握的基础技术,但是很多时候,你可能并不完全懂 Jav ...

  7. JRebel for IDEA插件 激活

    JRebel for IDEA 插件的License Server 程序,在IDEA中下载JREBEL的插件后,通过配置此服务进行插件激活. 使用方法:通过java -jar JrebelBrains ...

  8. jar包下不下来

    1.maven中的settings.xml文件中的镜像资源配置 <mirror> <id>alimaven</id> <name>aliyun mave ...

  9. 4、kubesphere环境安装

    安装步骤 选择4核8G(master).8核16G(node1).8核16G(node2) 三台机器,按量付费进行实验,CentOS7.9 安装Docker 安装Kubernetes 安装KubeSp ...

  10. (已解决)MYSQL怎么实现表的id在插入删除的前提下连续递增?

    其实就是用了sql语句. 思路是重置所有id和auto_increment. SET @i=0; UPDATE records SET id=(@i:=@i+1); ALTER TABLE recor ...