21.JVM的垃圾回收算法

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

一、标记-清除算法

1.概念

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

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

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

2.缺点

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

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


二、复制算法

1.概念

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

2.缺点

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


三、标记-整理算法

1.概念

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

2.STW

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


相关推荐
️是7813 小时前
信息奥赛一本通—编程启蒙(3373:练64.2 图像旋转翻转变换)
数据结构·c++·算法
m0_5150984213 小时前
如何创建哈希分区表_PARTITION BY HASH解决数据分布不均与热点块
jvm·数据库·python
qq_3729069313 小时前
如何处理SQL循环逻辑_探索递归CTE实现复杂计算
jvm·数据库·python
m0_6742946413 小时前
C#怎么使用Channel异步通道 C#如何用BoundedChannel实现有界队列限流异步数据流【进阶】
jvm·数据库·python
m0_7489203613 小时前
HTML函数在系统更新后变卡是硬件老化吗_软硬兼容性排查【方法】
jvm·数据库·python
weixin_4249993613 小时前
如何正确对对象键名进行字母序排序并存入数组
jvm·数据库·python
maqr_11013 小时前
如何配置Oracle 19c审计清理_DBMS_AUDIT_MGMT自动清除策略
jvm·数据库·python
qq_3729069313 小时前
如何用 JavaScript 实现单选式盒子颜色切换(点击高亮,其余复原)
jvm·数据库·python
2401_8971905513 小时前
怎样使用Navicat高级特权进行还原时解决字符集冲突_企业数据保护
jvm·数据库·python
木子墨51613 小时前
LeetCode 热题 100 精讲 | 计算几何篇:点积叉积 · 线段相交 · 凸包 · 多边形面积
c++·算法·leetcode·职场和发展·动态规划