标记 - 清除算法
来源:互联网 发布:12号铜壳在淘宝叫什么 编辑:程序博客网 时间:2024/04/29 23:06
. 标记 - 清除算法
(来自http://my.oschina.net/winHerson/blog/114391)
标记清除算法是最基础的收集算法,其他收集算法都是基于这种思想。标记清除算法分为“标记”和“清除”两个阶段:首先标记出需要回收的对象,标记完成之后统一清除对象。
它的主要缺点:①.标记和清除过程效率不高 。
②.标记清除之后会产生大量不连续的内存碎片。
、
2. 复制算法
它将可用内存容量划分为大小相等的两块,每次只使用其中的一块。当这一块用完之后,就将还存活的对象复制到另外一块上面,然后在把已使用过的内存空间一次理掉。这样使得每次都是对其中的一块进行内存回收,不会产生碎片等情况,只要移动堆订的指针,按顺序分配内存即可,实现简单,运行高效。
主要缺点:内存缩小为原来的一半。
3. 标记 - 整理算法
标记操作和“标记-清除”算法一致,后续操作不只是直接清理对象,而是在清理无用对象完成后让所有存活的对象都向一端移动,并更新引用其对象的指针。主要缺点:在标记-清除的基础上还需进行对象的移动,成本相对较高,好处则是不会产生内存碎片。
4、分代收集算法
根据对象的存活周期的不同将内存划分为几块。一般把java堆分为新生代和老年代,这样就可以根据各个年代的特点采用最适当的收集算法。在新生代,每次垃圾收集时都发现有大批对象死去,只有少量存活,那就选用复制算法,只需要付出少量存活对象的复制成本就可以完成收集。而老年代中因为对象存活率高、没有额外空间对他进行分配担保,就必须使用“标记-整理”算法进行回收。
1 0
- 标记-清除算法
- 标记 - 清除算法
- GC_2_标记-清除算法
- Elisp 标记-清除算法简介
- (转)标记-清除算法
- JVM-GC算法_标记清除算法
- 垃圾回收算法之标记-清除算法
- 垃圾回收算法之 标记-清除算法
- GC算法实践(四) 标记-清除算法
- 标记-清除( Mark-Sweep )算法
- java垃圾回收算法之-标记清除
- java垃圾回收算法之-标记清除
- JVM垃圾收集算法(标记-清除、复制、标记-整理)
- 标记-清除
- 标记-清除
- java垃圾回收算法之-标记__清除_压缩
- java垃圾回收算法之-CMS(并发标记清除)
- Java中JVM内存管理之标记/清除算法
- LeetCode --- 39. Combination Sum
- 毕业设计-微信公众平台开发与设计(三:网站)
- 棋盘覆盖-分治
- LeetCode --- 40. Combination Sum II
- Eclipse 生成webservice Client与JAX-WS不兼容问题解决
- 标记 - 清除算法
- 代码管理要责任到位
- webservice快速入门-使用JAX-WS注解的方式快速搭建ws服务端和客户端(一)
- vim环境配置之智能补全工具YouCompleteMe(YCM)的安装和配置
- #include<algorithm>包含的常用函数
- 2015-2-6工作日志-张吉林
- 分享一个android 访问http的类,非常好用哦
- Linux程序异常退出打印调用堆栈
- 小P的故事——神奇的分组(完全背包)