JVM的垃圾回收算法有哪些

标记清除算法

标记清除算法,是将垃圾回收分为2个阶段,分别是标记和清除

  1. 根据可达性分析算法得出的垃圾进行标记
  2. 对这些标记为可回收的内容进行垃圾回收
  • 优点:标记和清除速度较快
  • 缺点:碎片化较为严重,内存不连贯的

标记整理算法

优缺点同标记清除算法,解决了标记清除算法的碎片化的问题,同时,标记压缩算法多了一步,对象移动内存位置的步骤,其效率也有有一定的影响。老年代的垃圾回收器一般使用标记整理算法

复制算法

标记算法是将内存分成两块相等的区域,把标记的对象清除后,就会把存活的对象整理复制到另一块内存,一般年轻代的垃圾回收会采用复制算法

  • 优点
  1. 在垃圾对象多的情况下,效率较高
  2. 清理后,内存无碎片
  • 缺点

分配的2块内存空间,在同一个时刻,只能使用一半,内存使用率较低

相关推荐
菜鸟‍5 分钟前
【论文学习】Disco:基于邻接感知协同着色的密集重叠细胞实例分割方法
人工智能·学习·算法
牧天白衣.11 分钟前
力扣215.数组中的第K个最大元素
算法·leetcode
PrDf22Iw818 分钟前
编译执行与解释执行的区别是什么?JVM 使用哪种方式?
jvm
cxr82818 分钟前
控制理论基础
人工智能·算法
平平淡淡才是true31 分钟前
偏序关系、哈斯图、最长链长度、最长链条数
算法
小钊(求职中)36 分钟前
算法知识、常用方法总结
java·算法·排序算法·力扣
paeamecium41 分钟前
【PAT甲级真题】- Talent and Virtue (25)
数据结构·c++·算法·pat
Mr_Xuhhh1 小时前
蓝桥杯复习清单真题(C++版本)
c++·算法·蓝桥杯
tankeven1 小时前
HJ163 时津风的资源收集
c++·算法
Boop_wu1 小时前
[Java 算法] 动态规划(4)
数据结构·算法·leetcode