Java虚拟机学习 - 垃圾收集算法(3)
2024-08-25 12:06:02
跟踪收集器
跟踪收集器采用的为集中式的管理方式,全局记录对象之间的引用状态,执行时从一些列GC Roots的对象做为起点,从这些节点向下开始进行搜索所有的引用链,当一个对象到GC Roots 没有任 何引用链时,则证明此对象是不可用的。
下图中,对象Object6、Object7、Object8虽然互相引用,但他们的GC Roots是不可到达的,所以它们将会被判定为是可回收的对象。
可作为GC Roots 的对象包括:
虚拟机栈(栈帧中的本地变量表)中的引用对象。
方法区中的类静态属性引用的对象
方法区中的常量引用的对象
本地方法栈中JNI的引用对象。
主要有复制、标记清除、标记压缩三种实现算法。
1. 标记 - 清除算法
标记清除算法是最
它的主要缺点:
①.标记和清除过程效率不高
②.标记清除之后会产生大量不连续的内存碎片。
2. 复制算法
它将可用内存容量划分为大小相等的两块,每次只使用其中的一块。当这一块用完之后,就将还存活的对象复制到另外一块上面,然后在把已使用过的内存空间一次清理掉。这样使得每次都是对 其中的一块进行内存回收,不会产生碎片等情况,只要移动堆订的指针,按顺序分配内存即可,实现简单,运行高效。
主要缺点:
内存缩小为原来的一半。
3. 标记 - 整理算法
标记操作和“标记-
主要缺点:
在标记-清除的基础上还需进行对象的移动,成本相对较高,好处则是不会产生内存碎片。
引用计数收集器
引用计数收集器采用的是分散式管理方式,通过计数器记录对象是否被引用。当计数器为0时说明此对象不在被使用,可以被回收。
主要缺点:
循环引用的场景下无法实现回收,例如下面的图中,ObjectC和ObjectB相互引用,那么ObjectA即便释放了对ObjectC、ObjectB的引用,也无法回收。sunJDK在实现GC时未采用这种方式。
转自http://blog.csdn.net/java2000_wl/article/details/8022293
最新文章
- Chrome V8引擎系列随笔 (1):Math.Random()函数概览
- 推荐一个winform 界面交互类库转
- Spring @Transactional ——事务回滚
- 把对象转换成map
- CSS之clearfix清除浮动
- C语言博客作业--函数 陈张鑫
- UNIX环境高级编程——进程环境
- day01 进制转换与内存分布
- Linux下apache activemq的安装与配置
- 逆袭之旅DAY09.东软实训.接口
- day29-python阶段性复习三
- {python}完成完整的温度转换程序 猜数字游戏(猜价格,猜年龄等) 解析身份证号、学号不同片段的含义
- elasticsearch 口水篇(8)分词 中文分词 ik插件
- android开发学习笔记系列(3)--ScrollView与HorizontalScrollView
- 理解以太坊的Layer 2扩容解决方案:状态通道(State Channels)、Plasma 和 Truebit
- ZooKeeper ACL权限设置
- 一款经典的 jQuery Lightbox 灯箱效果
- HTML - SELECT默认选中
- 02.JMS基础
- 装饰器的修复wraps,偏函数partial 以及chain
热门文章
- Lua简明教程
- 500 OOPS: vsftpd: cannot locate user specified in 'chown_username':whoever
- @JVM垃圾收集器种类
- C++的Vector用法
- 两个List循环
- 结合实例详解";pure Virtual function called";
- 微信小程序Nginx环境配置
- UICamera(NGUI Event system)原理
- [Algorithm] Given the root to a binary tree, return the deepest node
- iOS开发系列课程预告