首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
编程语言
> 详细
GC原理---垃圾收集算法
时间:
2019-02-10 12:21:38
阅读:
214
评论:
0
收藏:
0
[点我收藏+]
标签:
对象
清理
分代
不同
连续
没有
就是
使用
开始
垃圾收集算法
Mark-Sweep(标记-清除算法)
标记清除算法分为两个阶段,标记阶段和清除阶段。标记阶段任务是标记出所有需要回收的对象,清除阶段就是清除被标记对象的空间。
优缺点:实现简单,容易产生内存碎片。因为会存在大量的空间碎片,因为回收后的空间是不连续的,这样给大对象分配内存的时候可能会提前触发full gc。
标记-压缩算法
首先也需要从根节点开始对所有可达对象做一次标记,但之后,它并不简单地清理未标记的对象,而是将所有的存活对象压缩到内存的一端。之后,清理边界外所有的空间。这种方法既避免了碎片的产生,又不需要两块相同的内存空间,因此,其性价比比较高。
标记-压缩算法是一种老年代的回收算法,它在标记-清除算法的基础上做了一些优化。
优缺点:不容易产生内存碎片;内存利用率高;存活对象多并且分散的时候,移动次数多,效率低下
复制算法
将现有的内存空间分为两快,每次只使用其中一块,在垃圾回收时将正在使用的内存中的存活对象复制到未被使用的内存块中,之后,清除正在使用的内存块中的所有对象,交换两个内存的角色,完成垃圾回收。
优缺点:不容易产生内存碎片;可用内存空间少;存活对象多的话,效率低下。
分代收集算法
当前商业虚拟机的垃圾收集都采用“分代收集”算法,该算法根据对象存活周期的不同,将内存划分为几块。一般把java堆划分为新生代和老年代,这样就可以根据各个年代的特点采用最适当的算法。
在新生代中,每次垃圾收集都发现有大批对象死去,只有少量存活,那就采用复制法,只需要付出少量存活对象的复制成本就可以完成收集
而老年代中对象存活率高,没有额外空间对它进行分配担保,就必须采用“标记-清除”算法或“标记-整理”算法来进行回收。
GC原理---垃圾收集算法
标签:
对象
清理
分代
不同
连续
没有
就是
使用
开始
原文地址:https://www.cnblogs.com/frankltf/p/10358755.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
Spring Cloud 从入门到精通(一)Nacos 服务中心初探
2021-07-29
基础的排序算法
2021-07-29
SpringBoot|常用配置介绍
2021-07-29
关于 .NET 与 JAVA 在 JIT 编译上的一些差异
2021-07-29
C语言常用函数-toupper()将字符转换为大写英文字母函数
2021-07-29
《手把手教你》系列技巧篇(十)-java+ selenium自动化测试-元素定位大法之By class name(详细教程)
2021-07-28
4-1 YAML配置文件 注入 JavaBean中
2021-07-28
【python】 用来将对象持久化的 pickle 模块
2021-07-28
马拉车算法
2021-07-28
用Python进行冒泡排序
2021-07-28
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!