21.JVM的垃圾回收算法

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

一、标记-清除算法

1.概念

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

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

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

2.缺点

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

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


二、复制算法

1.概念

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

2.缺点

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


三、标记-整理算法

1.概念

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

2.STW

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


相关推荐
清水白石0081 分钟前
模板方法模式全解析:用抽象基类定义算法骨架,让子类优雅填充细节
数据库·python·算法·模板方法模式
DeepModel2 分钟前
【分类算法】C4.5分类算法超详细讲解
算法·决策树·回归
@insist1234 分钟前
软考-数据库系统工程师-计算机存储层次结构与性能优化核心知识点
大数据·jvm·数据库
努力学算法的蒟蒻5 分钟前
day96(2.25)——leetcode面试经典150
算法·leetcode·面试
吕司7 分钟前
LeetCode Hot Code——找到字符串中所有字母异位词
算法·leetcode
AI科技星11 分钟前
物理世界的几何建构:论统一场论的本体论革命与概念生成
人工智能·opencv·线性代数·算法·矩阵
让我上个超影吧13 分钟前
【力扣34】在排序数组中查找元素的第一个和最后一个位置
java·数据结构·算法·leetcode
数据知道17 分钟前
MongoDB 数值更新原子操作:`$inc` 实现点赞、计数器等高并发原子操作
数据库·算法·mongodb
逆境不可逃24 分钟前
【从零入门23种设计模式08】结构型之组合模式(含电商业务场景)
线性代数·算法·设计模式·职场和发展·矩阵·组合模式
筱昕~呀24 分钟前
冲刺蓝桥杯-DFS板块(第二天)
算法·蓝桥杯·深度优先