jvm垃圾收集器总结jdk1.7
内存
● 线程私有:程序计数器,虚拟机栈,本地方法栈
● 线程共享: 方法区,堆
判断存活算法
● 引用计数法:无法解决循环引用问题。
● 可达性分析算法: 从GCRoot作为起始点,向下搜索,经过的路径成为引用链,当一个对象没有任何引用链相连(不可达时),则证明该对象不可用,进行第一次标记,如果第二次还不可用,则在gc时回收。
可作为GcRoot的对象:
● 虚拟机栈中引用的对象。
● 方法区中类静态属性引用的对象
● 方法区中常量引用的对象
● 本地方法栈中JNI引用的对象
Java引用类型:
● 强引用: 最普遍的,new出来的对象
● 软引用: 有用但非必须的对象,在oom时,进行回收
● 弱引用: 非必须的对象,下次gc时回收
● 虚引用:一个对象是否有虚引用完全不会对其生存时间构成影响,虚引用的唯一目的是能在这个对象被收集器时收到一个系统通知。
回收方法区:
方法区回收性价比低,主要回收两部分:废弃常量和无用的类。判断为无用的类条件:
1.该类所有实例已经被回收
2.加载该类的classloader已经被回收
3.该类的java.lang.class对象没有在任何地方引用,无法通过放射访问该类的方法。
垃圾收集算法
- 标记-清除算法:
● 先标记后回收
● 缺点:效率问题,标记和清除效率都不高,空间问题,清除以后会产生大量内存碎片
2.复制算法:
● 将survivor(存活区)分两块,由于大部分对象(98%)都是"朝生夕死"所以将Eden区和正在使用的survivor区复制到另一个survivor区,eden:survivor 8:1左右。并且有老年区担保机制
● 适合于年轻代
3.标记整理算法:
● 标记之后让存活对象往一端移动,清除另一段的无用对象
● 适合于老年代
4.分代收集:
● 新生代采用复制算法,老年代采用标记整理算法
Hotspot算法实现
● GCRoots:在oopmap的协助下,快速完成GCRoots枚举,oopmap只有在某些代码位置生成,在安全点(方法调用返回,可能异常点,循环跳转)中断进行回收。改进为安全区域(无引用关系变化
垃圾收集器
● serial收集器:单线程收集器,stop the world,
● ParNew收集器:Serial多线程版本,能与cms搭配。
● Parallel Scavenge收集器:自适应调节策略,高吞吐量,多线程并行,
● CMS收集器:以获取最短回收停顿时间为目标的收集器。四个步骤:1.初始标记 2.并发标记,3.重新标记,4.标记清除。初始标记和重新标记需要停顿,这段时间较短, 并发标记和并发清除时间长,cms并发执行。
缺点:无法处理浮动垃圾。内存碎片。
● G1收集器:
1.并行与并发 2.分代收集 3.空间整合 4.可预测停顿。
可用于新生代和老年代,内存中它们不再隔离。跟踪合个region里的价值大小维护优先列表,每次根据允许的收集时间,优先回收价值最大的region。
jvm垃圾收集器总结jdk1.7的更多相关文章
- 7种JVM垃圾收集器特点,优劣势、及使用场景
今天继续JVM的垃圾回收器详解,如果说垃圾收集算法是JVM内存回收的方法论,那么垃圾收集器就是内存回收的具体实现. 一.常见的垃圾收集器有3类 1.新生代的收集器包括 Serial PraNew Pa ...
- 第五章 JVM垃圾收集器(1)
说明:垃圾回收算法是理论,垃圾收集器是回收算法的实现,关于回收算法,见<第四章 JVM垃圾回收算法> 1.七种垃圾收集器 Serial(串行GC)-- 复制 ParNew(并行GC)-- ...
- JVM垃圾收集器(1)
此文已由作者赵计刚薪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 说明:垃圾回收算法是理论,垃圾收集器是回收算法的实现,关于回收算法,见<第四章 JVM垃圾回收算法& ...
- 5种JVM垃圾收集器特点和8种JVM内存溢出原因
先来看看5种JVM垃圾收集器特点 一.常见垃圾收集器 现在常见的垃圾收集器有如下几种: 新生代收集器: Serial ParNew Parallel Scavenge 老年代收集器: Serial O ...
- 7种 JVM 垃圾收集器特点、优劣势及使用场景(多图)
7种 JVM 垃圾收集器特点.优劣势及使用场景(多图) mp.weixin.qq.com 点击上方"IT牧场",选择"设为星标"技术干货每日送达! 一.常见垃 ...
- JVM调优:HotSpot JVM垃圾收集器
HotSpot JVM垃圾收集器 - Snooper - 博客园https://www.cnblogs.com/snooper/p/8718478.html
- JVM垃圾收集器-Parallel Scavenge收集器
今天我给大家讲讲JVM垃圾收集器-Parallel Scavenge收集器 Parallel Scavenge收集器 Parallel Scavenge收集器也是一个新生代收集器,它也是使用复制算法的 ...
- 【006】【JVM——垃圾收集器总结】
Java虚拟机学习总结文件夹 JVM--垃圾收集器总结 垃圾收集器概览 收集算法是内存回收的方法论.垃圾收集据是内存回收的详细实现.Java虚拟机规范中对垃圾收集器应该怎样实现没有规定.不同的厂 ...
- 第六章 JVM垃圾收集器(2)
上一章记录了几种常见的垃圾收集器,见<第五章 JVM垃圾收集器(1)> 1.G1 说明: 从上图来看,G1与CMS相比,仅在最后的"筛选回收"部分不同(CMS是并发清除 ...
随机推荐
- 【Luogu3807】【模板】卢卡斯定理(数论)
题目描述 给定\(n,m,p(1≤n,m,p≤10^5)\) 求 \(C_{n+m}^m mod p\) 保证\(P\)为\(prime\) \(C\)表示组合数. 一个测试点内包含多组数据. 输入输 ...
- .NET Core使用skiasharp文字头像生成方案(基于docker发布)
一.问题背景 目前.NET Core下面针对于图像处理的库微软并没有集成,在.NET FrameWork下我们已经习惯使用System.Drawing类库做简单的图像处理,到了.NET Core下一脸 ...
- angularJs $mdDialog和$uibModal弹框关闭传值
$mdDialog以一个点击button按钮出现弹框为例: $scope.btn=function($event,row){ var dScope = $scope.$new(true); dScop ...
- Django Middleware简介
1 前言 Django使用非常熟练了,各种API接口不在话下,全都搞定.为方便定位问题在每个API接口的的开始和返回的地方都加上了log打印,记录入参和返回值. 但是这样有一个问题,需要每个 ...
- 【learning】一般图最大匹配——带花树
问题描述 对于一个图\(G(V,E)\),当点对集\(S\)满足任意\((u,v)\in S\),均有\(u,v\in V,(u,v)\in E\),且\(S\)中没有点重复出现,我们称\(S\) ...
- Django中下划线的用法介绍(一)
在Django中有相当多的操作是通过双下划线与动作连接起来使用,为了以后更加方便的查找和使用,现在总结以下Django中基本的双下划线操作 比较符:大于--gt 小于--lt 等于--eq 大于等 ...
- Cassandra配置多节点集群以及使用雅虎YCSB压测Cassandra 3.11
这几天在搭Cassandra集群以及对Cassandra的性能测试,步骤还挺多,记录一下. 关于Caaandra在服务器上配置多节点集群,可以参考一下文章: http://blog.csdn.net/ ...
- WordPress源代码压缩优化及常见问题的解决
先来看看效果: 意思就是让你的源代码看起来都挤在一起,这样如果别人想看你的源代码的话就不容易看懂了,(当然如果别人实在想看的话也可以通过某些软件的整理代码的功能来实现,比如IDEA的Ctrl+alt+ ...
- Silverlight的认识
Microsoft Silverlight是一个跨浏览器的.跨平台的插件.Silverlight提供灵活的编程模型,并可以很方便地集成到现有的网络应用程序中.Silverlight可以对运行在Mac或 ...
- java中equals方法和hashcode方法的区别和联系,以及为什么要重写这两个方法,不重写会怎样
一.在Object类中的定义为:public native int hashCode();是一个本地方法,返回的对象的地址值.但是,同样的思路,在String等封装类中对此方法进行了重写.方法调用得到 ...