JDK1.7 Update14 HotSpot虚拟机GC收集器】的更多相关文章

在测试服务器上使用如下命令可以查看当前使用的 GC收集器,当然不止这一个命令可以看到,还有其他一些方式 第三列”=”表示第四列是参数的默认值,而”:=” 表明了参数被用户或者JVM赋值了 [csii@devpwcoreapp bin]$ ./java -XX:+PrintFlagsFinal -version | grep : uintx InitialHeapSize := {product} uintx MaxHeapSize := {product} uintx ParallelGCThr…
GC回收算法 1.标记清除算法分为标记阶段和清除阶段标记阶段:通过特定的判断方式找出无用的对象实例并将其标记清除阶段:将已标记的对象所占用的内存回收缺点:运行多次以后容易产生空间碎片,当需要一整段连续内存时虽然空间足够但是无法分配,会多次触发GC操作. 2.复制算法为了提高标记清除算法的效率,减少内存碎片的产生而出现的,该算法将内存空间分为两个完全相同的两部分,每次只使用其中的一部分.分为标记阶段.复制阶段和清除阶段标记阶段:同标记清除算法的标记阶段一致复制阶段:将为标记的对象全部复制到另一块未…
1. 前言 在上一篇文章中,介绍了JVM中垃圾回收的原理和算法.介绍了通过引用计数和对象可达性分析的算法来筛选出已经没有使用的对象,然后介绍了垃圾收集器中使用的三种收集算法:标记-清除.标记-整理.标记-复制算法. 介绍完原理,在这篇文章中,我们将介绍当前JVM中已经实现的垃圾收集器,以及与收集器主题相关的一些内容. 首先,我们将在上一篇文章中提到分代收集机制的基础上,介绍下现代商业JVM中普遍采用的分代回收策略.然后,按照内存分代划分的维度介绍下当前JVM中实现的收集器.最后,学习分析不同收集…
转载:https://wangkang007.gitbooks.io/jvm/content/la_ji_shou_ji_qi.html 收集器 1.1 Serial(串行)收集器 Serial收集器是一个新生代收集器(Serial Old对应老年代),单线程执行,使用复制算法.它在进行垃圾收集时,必须暂停其他所有的工作线程(用户线程)也就是传说中的Stop The World.是Jvm client模式下默认的新生代收集器.对于限定单个CPU的环境来说,Serial收集器由于没有线程交互的开销…
[概述] 如果说收集算法是内存回收的方法论,那么垃圾收集器就是内存回收的具体实现.Java 虚拟机规范中对垃圾收集器应该如何实现没有任何规定,因此不同的厂商.不同版本的虚拟机所提供的垃圾处理器都可能会有很大差别,并且一般都会提供参数供用户根据自己的应用特点和要求组合出各个年代所使用的收集器.下图为 HotSpot 虚拟机的垃圾收集器: 上图展示了7种用于不同分代的收集器,其中新生代的收集器有:Serial .ParNew.Parallel Scavenge, 老年代的收集器有:Serial Ol…
一.前言 前文学习了各种GC回收算法,掌握了GC回收的原理,但是真正的GC实现却尤为复杂,本篇文章将主要介绍各种GC收集器. 目前主流的HotSpot VM支持多种虚拟机,这些虚拟机也体现了GC的发展历程,从单线程GC到多线程GC,分代GC到G1 GC. 本文主要从以下几个方面介绍GC收集器: 各种GC的特点 GC匹配和参数使用 GC日志格式 常用的GC参数总结 二.各种GC的特点 HotSpot中采用分代GC,从早期的单线程串行Garbage Collector到后面的多线程并行Garbage…
根据Java GC收集器具体分类,我们可以看出JVM根据需求不同提供了三种选择:串行收集器.并行收集器.并发收集器. 串行收集器只适用于小数据量的情况,我们主要了解一下并行收集器和并发收集器.默认情况下,JDK5.0以前都是使用串行收集器,如果需要使用其他收集器需要在启动的是时候加入相应的参数.JDK5.0以后,JVM会根据当前系统的配置进行判断. 我们先了解一下什么是并行和并发? 并行:指多条垃圾收集器线程并行工作,但此时仍是“Stop The World”状态,即用户线程处于等待状态: 并发…
名称 过程 优缺点 Serial 进行垃圾收集时,必须暂停其他所有的工作进程,直到它收集结束.是一个单线程收集器. Stop the world. 新生代收集器. 手工设置新生代的大小:-Xmn Eden与Survivor区的比例:-XX:SurvivorRatio 晋升老年代对象年龄:-XX:PretenureSizeThreshold 简单而高效(运行在Client默认新生代收集器) 对于Client模式下的虚拟机来说是一个很好的选择. ParNew 就是Serial收集器的多线程版本. 新…
新生代收集器 Serial New 单线程收集器,工作时必须暂停其他线程: 简单高效,没有线程交互开销: 基于复制算法: Parallel New 对Serial的改进,多线程: CPU数量<4时,性能并不比Serial好: CMS新生代的默认收集器: 基于复制算法: Parallel Scavenge 复制算法: 更关注吞吐量,吞吐量 = 运行用户代码时间 / (运行用户代码时间 + 垃圾收集时间): 不能和CMS配合工作 老年代收集器 Serial Old 标记-整理算法 单线程,性能不行:…
1.Serial收集器一个单线程的收集器,在进行垃圾收集时候,必须暂停其他所有的工作线程直到它收集结束.特点:CPU利用率最高,停顿时间即用户等待时间比较长.适用场景:小型应用通过JVM参数-XX:+UseSerialGC可以使用串行垃圾回收器. 2.Parallel收集器采用多线程来通过扫描并压缩堆特点:停顿时间短,回收效率高,对吞吐量要求高.适用场景:大型应用,科学计算,大规模数据采集等.通过JVM参数 XX:+USeParNewGC 打开并发标记扫描垃圾回收器. 3.CMS收集器采用“标记…