垃圾收集算法 灰太狼 2023-10-01 21:12 3阅读 0赞 ## 一、新生代和老年代 ## 新生代:主要存放新创建的对象,内存大小相对比较小,垃圾回收频繁。 老年代:存放生命周期比较长的对象,内存大小相对比较大,垃圾回收也没有那么频。 两者联系:在新生代中,每次垃圾收集时都发现有大批对象死去,而每次回收后存活少量的对象,及那个会逐步晋升到老年代中存放。 跨代引用:跨代引用是指新生代中存在对老年代对象的引用,或者老年代中存在对新生代的引用。 ## 二、标记 - 清除算法 ## 如名字一样,此算法分为“标记” 和 “清除” 两个阶段:首先标记出所有需要回收的对象,在标记完成后,同一回收掉所有被标记的对象,也可以反过来,标记存活的对象,同一回收所有未标记的对象。标记过程就是对象是否属于垃圾的判断过称。 标记 - 清除算法的缺点: 1.执行效率不稳定 当Java堆中包含大量对象,而其中大部分是需要被回收的,这时必须进行大量标记和清除动作,导致标记和清除两个过程的执行效率都随对象数量的增长而降低。 2.内存空间碎片化问题 标记、清除之后会产生大 量不连续的内存碎片,空间碎片太多可能会导致当以后在程序运行过程中需要分配较大对象时无法找 到足够的连续内存而不得不提前触发另一次垃圾收集动作。 ![watermark_type_d3F5LXplbmhlaQ_shadow_50_text_Q1NETiBAY3JhenlLLg_size_20_color_FFFFFF_t_70_g_se_x_16][] ## 三、标记 - 复制算法 ## 简称为复制算法,为了解决标记 - 清除算法面对大量对象回收效率低的问题。此算法把内存分成了两块相同大小的内存空间,当A空间的内存用完了,就把A空间上存活的对象复制到B空间上,然后把A空间清理掉;B空间也是如此。这样实现简单,运行高效。 标记 - 复制算法的缺点:将可用内存缩小到原来的一半,空间浪费过大。 ![watermark_type_d3F5LXplbmhlaQ_shadow_50_text_Q1NETiBAY3JhenlLLg_size_20_color_FFFFFF_t_70_g_se_x_16 1][] ## 四、标记 - 整理算法 ## 标记-复制算法在对象存活率较高时就要进行较多的复制操作,效率将会降低,所以在老年代中不能执行这种操作。针对老年代的对象存亡特征,出现了 标记 - 整理算法,标记过程与标记 - 清除算法一样,但标记完是让所有存活对象都向内存空间一端移动,然后直接清理掉边界以外的内存。 ![watermark_type_d3F5LXplbmhlaQ_shadow_50_text_Q1NETiBAY3JhenlLLg_size_20_color_FFFFFF_t_70_g_se_x_16 2][] [watermark_type_d3F5LXplbmhlaQ_shadow_50_text_Q1NETiBAY3JhenlLLg_size_20_color_FFFFFF_t_70_g_se_x_16]: https://img-blog.csdnimg.cn/8dfe8e96f54c4820b466603c83575ae0.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAY3JhenlLLg==,size_20,color_FFFFFF,t_70,g_se,x_16 [watermark_type_d3F5LXplbmhlaQ_shadow_50_text_Q1NETiBAY3JhenlLLg_size_20_color_FFFFFF_t_70_g_se_x_16 1]: https://img-blog.csdnimg.cn/b2e72bc4bf44472e8629e75e990f07e6.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAY3JhenlLLg==,size_20,color_FFFFFF,t_70,g_se,x_16 [watermark_type_d3F5LXplbmhlaQ_shadow_50_text_Q1NETiBAY3JhenlLLg_size_20_color_FFFFFF_t_70_g_se_x_16 2]: https://img-blog.csdnimg.cn/aeac287172084fc9ac158979339bf67c.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAY3JhenlLLg==,size_20,color_FFFFFF,t_70,g_se,x_16
相关 垃圾收集算法 一、新生代和老年代 新生代:主要存放新创建的对象,内存大小相对比较小,垃圾回收频繁。 老年代:存放生命周期比较长的对象,内存大小相对比较大,垃圾回收也没有那么频。 两 灰太狼/ 2023年10月01日 21:12/ 0 赞/ 4 阅读
相关 垃圾收集算法 标记-清除算法 Mark-Sweep 首先标记出所有需要回收的对象,在标记完成后统一回收所有被标记的对象。 由两个不足: 1. 效率问题 今天药忘吃喽~/ 2023年07月04日 04:52/ 0 赞/ 20 阅读
相关 垃圾收集算法 对象已死吗 引用计数法 > 给对象中添加一个引用计数器,每当一个地方引用它时,计数器值就加1;当引用失效时,计数器值就减1;任何时刻计数器为0的对象就是不可能再被使 喜欢ヅ旅行/ 2023年06月03日 12:59/ 0 赞/ 30 阅读
相关 垃圾收集算法 1.标记-清除算法 标记处所有需要回收的对象,标记完成之后统一回收所有被标记的对象 不足之处:效率问题,标记和清除两个过程的效率都不高,空间问题:会产生很多内存碎片,以后在 ╰半橙微兮°/ 2023年03月12日 09:19/ 0 赞/ 22 阅读
相关 垃圾收集算法 垃圾收集器与内存分配策略参考目录: > 1.[判断Java 对象实例是否死亡][Java] > 2.[ Java 中的四种引用][Java 1] > 3.[垃圾收集算 秒速五厘米/ 2022年06月04日 05:24/ 0 赞/ 234 阅读
相关 垃圾收集算法 由于垃圾算法的实现涉及大量程序细节,而且各个平台的虚拟机操作内存的方法又各不相同,因此我们不需要过多关注算法的实现。只需要了解算法的思想和发展 1、标记-删除算法 ![ 深碍√TFBOYSˉ_/ 2022年05月14日 14:23/ 0 赞/ 239 阅读
相关 垃圾收集算法 垃圾收集算法 标记-清除算法 复制算法 标记-整理算法 分代收集算法 标记-清除算法 最基础的收集算法是“标 r囧r小猫/ 2022年03月10日 13:19/ 0 赞/ 281 阅读
相关 垃圾收集算法 标记-清除算法 其他算法的基础 主要问题: 1、效率低 2、造成大量内存碎片 复制算法 为了解决标记-清除算法的缺陷,将内存开成两个相等区域,对象动态 ╰+哭是因爲堅強的太久メ/ 2022年02月01日 07:45/ 0 赞/ 278 阅读
相关 垃圾收集算法 垃圾收集算法 标记-清除算法 复制算法 标记-整理算法 分代收集算法 标记-清除算法 最基础的收集算法是“标记-清除“算法,算法分为“标记 - 日理万妓/ 2021年09月24日 01:20/ 0 赞/ 331 阅读
相关 垃圾收集算法 由于垃圾收集算法的实现涉及大量的程序细节,而且各个平台的虚拟机操作内存的方法又各不相同,因此本节不打算过多地讨论算法的实现,只是介绍几种算法的思想及其发展过程。 小灰灰/ 2020年05月14日 16:09/ 0 赞/ 808 阅读
还没有评论,来说两句吧...