性能优化|面试过程中,会点JVM知识会更加分哦

性能优化|垃圾回收算法

标记-清除算法

标记-清除分为标记和清除两个阶段,在标记阶段jvm会在需要回收的对象上面打上标记,标记阶段完成后,jvm开始执行清除动作,这个阶段会清除掉那些被标记的需要回收的对象。
内存整理前后对比:
黑色是存活对象,灰色是垃圾对象
在这里插入图片描述
在这里插入图片描述

结论:使用标记-清除算法,清理垃圾后会发现存活对象分布的位置比较零散,如果有有大对象需要分配的话,很难有连续的空间进行分配;
缺点:效率低、空间碎片

复制算法

为了解决内存碎片问题,jvm大师们研究出了复制算法,复制算法的原理是将内存空间分为两块,当其中一块内存使用完之后,就会将存活对象复制到另外一块内存上,将之前的内存块直接清理掉,这样就不会产生内存碎片的问题了。
使用复制算法,内存前后对比
在这里插入图片描述
在这里插入图片描述

结论:解决了内存碎片的问题,但是会导致内存空间缩减一半,适用于存活对象少的区域。

标记整理算法

标记整理算法的步骤和标记-清除是一样的,不过最后多加一步就是整理,用来整理存活对象造成的内存碎片,使用标记-整理后内存前后对比:

在这里插入图片描述
在这里插入图片描述

结论:可以看出,执行标记-整理 之后,没有出现内存碎片,所有存活对象被移到了一边。

分代收集算法

分代收集算法主要就是将内存分为两个年代,一个是年轻代,一个是老年代,在年轻代中使用复制算法,因为年轻代存活的对象少,比较适合使用复制算法,老年代使用标记整理算法,因为老年代垃圾比较少,所以适用于标记整理算法

微信搜一搜【乐哉开讲】关注帅气的我,回复【干货领取】,将会有大量面试资料和架构师必看书籍等你挑选,包括java基础、java并发、微服务、中间件等更多资料等你来取哦。

猜你喜欢

转载自blog.csdn.net/weixin_34311210/article/details/109447191
今日推荐