21.JVM的垃圾回收算法

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

一、标记-清除算法

1.概念

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

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

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

2.缺点

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

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


二、复制算法

1.概念

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

2.缺点

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


三、标记-整理算法

1.概念

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

2.STW

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


相关推荐
akarinnnn3 分钟前
深入理解内存函数:原理、应用与优化
c语言·网络·数据结构·算法
Dicky-_-zhang6 分钟前
线上故障排查与应急响应实战:从零开始建立你的SRE体系
java·jvm
大大杰哥6 分钟前
从 Volatile 到 ThreadLocal:Java 线程安全机制备忘
java·开发语言·jvm
一行代码一行诗++11 分钟前
for循环中的break和continue
数据结构·算法
AI人工智能+电脑小能手13 分钟前
【大白话说Java面试题 第67题】【JVM篇】第27题:生产环境服务器变慢,诊断思路和性能评估谈谈?
java·服务器·jvm·面试
Tisfy14 分钟前
LeetCode 3043.最长公共前缀的长度:哈希表(不转string)
算法·leetcode·散列表·题解·哈希表
代码中介商15 分钟前
排序算法完全指南(三):插入排序深度详解
算法·排序算法
承渊政道19 分钟前
【贪心算法】(经典实战应用解析(六):整数替换、俄罗斯套娃信封问题、可被三整除的最⼤和、距离相等的条形码、重构字符串)
c++·算法·leetcode·贪心算法·排序算法·动态规划·哈希算法
WL_Aurora22 分钟前
Python 算法基础篇之排序算法(二):希尔、快速、归并
python·算法·排序算法
闻缺陷则喜何志丹27 分钟前
【图论 树 启发式合并】P7165 [COCI2020-2021#1] Papričice|普及+
c++·算法·启发式算法·图论··洛谷