今天给大家继续分享JVM垃圾回收算法相关知识。列之M垃 JVM垃圾回收算法主要有标记清除、收算识复制算法、法相标记整理、关知分代收集四种,列之M垃下面来逐一介绍。收算识 标记清除作为最基础的关知垃圾回收算法,其过程要经历两个阶段:标记、列之M垃回收。收算识 标记:遍历内存区域,法相标记出待回收的关知对象。 回收:再次遍历内存区域,列之M垃然后对已标记的收算识对象占用的内存进行回收。 复制算法主要是解决标记—清除算法遍历的亿华云计算和产生内存碎片的缺点,在其基础上进行改进而来的,它会将可用内存按容量分为大小相等的两块,每次只能使用其中的一块,当正在使用的这一块的内存空间不满足使用的时候,就会将还存活的对象复制到另外一块空的内存上面,然后再把当前内存空间一次清理掉。 复制算法在新生代中两个幸存区(From 、To)的不停交换是最典型的用法。 新生代内存空间占比为 8(Eden 伊甸园区 ):1 (To Survivor):1 (Survivor From)。 优点 缺点: 一次性分配内存只能用其中的一半,网站模板内存的最大可利用率只有一半。 标记整理算法主要是针对老年代来设计的。 执行过程: 优点: 缺点: 严格意义上来说分代收集不能算一种新的垃圾回收算法,分代收集其实只是源码库根据对象的存活的时间的长短,将新生代和老年代针对不同的内存区域,采取对应的算法。目前市面上大多商用虚拟机都采用分代收集算法。 新生代:每次都有大量对象消亡,因为有老年代作为内存担保,比较采取复制算法。 老年代:对象存活时间长,可采用标记整理、标记清除算法。 对比参数 标记清除 标记整理 标记复制 速度 中等 最慢 最快 空间开销 少(会产生碎片) 少(不会产生碎片) 2倍开销 移动对象 否 是 是 适合场景 老年代 老年代 新生代1、法相标记清除(Mark-Sweep)
2、复制算法(Copy)
3、标记整理(Mark-Compact)
4、分代收集算法
5、三种垃圾回收算法对比