JVM的垃圾回收算法和多种GC算法

GC也就是java的垃圾回收机制作用区域如下:

JVM在进行垃圾回收的时候,并不是在新生区,养老区,元空间这三个区域统一回收的,大部分的时候,回收的都是新生区。新生区的幸存区可以分为from和to

GC的两种类:轻GC(普通GC),重GC(全局GC)

GC常考的问题:

  • JVM的内存模型和分区,每个分区放的什么?

  • 堆里面的分区都有哪些?说说它们的特点。

  • GC算法有哪些?

  • 轻GC和重GC分别发生在什么时候?

GC的算法:

引用计数法
复制算法:
  • 复制算法主要的作用范围就在新生区,在这个算法当中重点在于复制,也就是说幸存区里面有from和to这两个划分,我们的新生区在进行GC清理之后都会将Eden区的幸存对象转移到幸存区里面,如果转移到了from区,那么就无事发生,如果转移到了to区,那么就会从to区复制到from区里面,如果二者都有幸存对象,那么同样to区的会把幸存者复制到from区,所以我们要保证to区里面是没有幸存者的

  • 当一个对象默认经历了15次GC之后还没有被淘汰,那么就会被送入养老区这个参数是可以进行调整的-XX:MaxTenuringThreshold=?具体数值根据实际需求进行调整

  • 复制算法好处:没有内存的碎片,很整洁。

    坏处:浪费了一个幸存区的内存空间,to区永远为空。

复制算法的使用场景,对象存活度较低的时候。

标记清除算法

优点:不需要额外的空间。

缺点:两次扫描,浪费了时间,会产生内存碎片。

标记压缩算法

在标记清除的算法上面进行了优化

还有一种标记清除压缩,也不算是一种新的算法,也就是说我们进行多次的GC清除然后在进行压缩。

总结:

  • 内存效率:复制算法>标记清除算法>标记压缩算法(时间复杂度排序)。
  • 内存整齐度:复制算法=标记压缩算法>标记清除算法
  • 内存利用率:标记压缩算法=标记清除算法>复制算法

我们可以通过上面了解到,我们的GC算法并没有最好的,所以我们只能在不同情况下最合适的算法。

我们的GC分代收集算法:

年轻代:存活率低选择复制算法。

老年代:区域大,存活率高,在内存碎片不是很多的情况下,我们使用标记清除压缩算法。

相关推荐
vx1_Biye_Design8 分钟前
基于Spring Boot+Vue的学生管理系统设计与实现-计算机毕业设计源码46223
java·vue.js·spring boot·spring·eclipse·tomcat·maven
vx_Biye_Design9 分钟前
基于Spring Boot+vue的湖北旅游景点门票预约平台的设计--毕设附源码29593
java·vue.js·spring boot·spring cloud·servlet·eclipse·课程设计
啊阿狸不会拉杆16 分钟前
《机器学习导论》第 5 章-多元方法
人工智能·python·算法·机器学习·numpy·matplotlib·多元方法
hay_lee28 分钟前
Spring AI实现对话聊天-流式输出
java·人工智能·ollama·spring ai
Hx_Ma1634 分钟前
SpringBoot数据源自动管理
java·spring boot·spring
SunnyDays101134 分钟前
Java 高效实现 CSV 转 Excel
java·csv转excel
starfire_hit36 分钟前
JAVAWEB根据前台请求获取用户IP
java·服务器·网络
fengxin_rou37 分钟前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿
java·redis·缓存·mybatis·idea·多线程
像少年啦飞驰点、40 分钟前
从零开始学 RabbitMQ:小白也能懂的消息队列实战指南
java·spring boot·微服务·消息队列·rabbitmq·异步编程
宠友信息1 小时前
2025社交+IM及时通讯社区APP仿小红书小程序
java·spring boot·小程序·uni-app·web app