21.JVM的垃圾回收算法

JVM的垃圾回收算法主要有三种:

一、标记-清除算法

1.概念

标记-清除算法分为两个阶段:

a.标记阶段:会遍历所有的对象,标记出需要回收的对象。

b.清除阶段:会再次遍历所有的对象,回收被标记了的对象。

2.缺点

a.执行效率不稳定:如果Java堆中有大量的对象,而且其中大部分需要被回收。那么就会导致标记和清除两个阶段的执行效率因为对象数量的增加而不断降低。

b.标记和清除之后会产生大量不连续的内存碎片,导致内存空间的浪费。


二、复制算法

1.概念

复制算法是将可用的内存空间划分为大小相等的两块区域,每次只使用其中的一块区域。当这块区域用完了,就将还存活的对象复制到另一块区域,然后把使用过的这一块内存区域一次性清理掉。

2.缺点

也会有一部分内存空间没有使用,存在空间的浪费。


三、标记-整理算法

1.概念

标记-整理算法是在标记-清除算法的基础上进行改进,它的标记阶段与标记-清除算法一样,但后续不是直接清除可回收对象。而是将所有存活的对象移动到内存空间的一端,然后直接清理掉边界以外的内存空间。(移动存活对象需要STW( Stop The World)才能进行)

2.STW

进行垃圾回收过程中会涉及对象的移动,那么为了保证对象引用更新的正确性,必须暂停所有的用户线程。这样的停顿,被描述为STW( Stop The World)。


相关推荐
一个不知名程序员www17 小时前
算法学习入门---二分查找(C++)
c++·算法
2301_8079973817 小时前
代码随想录-day26
数据结构·c++·算法·leetcode
闭着眼睛学算法17 小时前
【双机位A卷】华为OD笔试之【排序】双机位A-银行插队【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·javascript·c++·python·算法·华为od
TL滕17 小时前
从0开始学算法——第一天(认识算法)
数据结构·笔记·学习·算法
小欣加油17 小时前
leetcode 3318 计算子数组的x-sum I
c++·算法·leetcode·职场和发展
love is sour18 小时前
聚类(Clustering)详解:让机器自己发现数据结构
算法·支持向量机·聚类
烟袅18 小时前
LeetCode 142:环形链表 II —— 快慢指针定位环的起点(JavaScript)
前端·javascript·算法
CoovallyAIHub18 小时前
OCR战场再起风云:LightOnOCR-1B凭什么比DeepSeekOCR快1.7倍?(附演示开源地址)
深度学习·算法·计算机视觉
海琴烟Sunshine19 小时前
leetcode 190. 颠倒二进制位 python
python·算法·leetcode
Xの哲學19 小时前
Linux eMMC子系统深度解析:从硬件协议到内核实现
linux·网络·算法·架构·边缘计算