📕我是廖志伟,一名Java开发工程师、《Java项目实战——深入理解大型互联网企业通用技术》(基础篇)、(进阶篇)、(架构篇)清华大学出版社签约作家、Java领域优质创作者、优快云博客专家、阿里云专家博主、51CTO专家博主、产品软文专业写手、技术文章评审老师、技术类问卷调查设计师、幕后大佬社区创始人、开源项目贡献者。
📘拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、SpringBoot、SpringMVC、SpringCloud、Mybatis、Dubbo、Zookeeper),消息中间件底层架构原理(RabbitMQ、RocketMQ、Kafka)、Redis缓存、MySQL关系型数据库、 ElasticSearch全文搜索、MongoDB非关系型数据库、Apache ShardingSphere分库分表读写分离、设计模式、领域驱动DDD、Kubernetes容器编排等。不定期分享高并发、高可用、高性能、微服务、分布式、海量数据、性能调优、云原生、项目管理、产品思维、技术选型、架构设计、求职面试、副业思维、个人成长等内容。

🌾阅读前,快速浏览目录和章节概览可帮助了解文章结构、内容和作者的重点。了解自己希望从中获得什么样的知识或经验是非常重要的。建议在阅读时做笔记、思考问题、自我提问,以加深理解和吸收知识。阅读结束后,反思和总结所学内容,并尝试应用到现实中,有助于深化理解和应用知识。与朋友或同事分享所读内容,讨论细节并获得反馈,也有助于加深对知识的理解和吸收。💡在这个美好的时刻,笔者不再啰嗦废话,现在毫不拖延地进入文章所要讨论的主题。接下来,我将为大家呈现正文内容。

一、JVM知识体系
类加载机制
类加载机制在JVM中扮演着至关重要的角色,它负责将编译后的Java字节码文件(.class文件)转换成JVM能够识别的类对象。类加载过程涉及以下几个关键步骤:
-
加载:类加载器首先需要定位到.class文件的存储位置,然后通过字节码加载器将字节码数据读入内存。这一步通常涉及以下细节:
- 类加载器:负责加载类的字节码到内存中,包括Bootstrap ClassLoader、Extension ClassLoader和Application ClassLoader。
- 类文件结构:类文件中包含了类的基本信息、字段、方法、属性等,类加载器需要解析这些信息并构建类对象。
-
验证:验证过程确保加载的类信息符合JVM规范,包括字节码的校验、符号引用的验证等。这一步骤包括以下细节:
- 字节码校验:检查字节码是否符合JVM指令集规范。
- 符号引用验证:确保类中引用的其他类或接口存在,以及类中的字段和方法的访问权限是否正确。
-
准备:为类变量分配内存并设置默认初始值。对于基本数据类型,初始值为0、false或null;对于对象类型,初始值为null。
-
解析:将符号引用转换为直接引用,即将类、接口、字段和方法的符号引用替换为直接引用。
-
初始化:执行类构造器方法,初始化类变量。这个过程可能涉及初始化代码,例如静态初始化块。
双亲委派模型
双亲委派模型是JVM中类加载器的一种层次结构,它要求除了顶层的启动类加载器外,其余的类加载器都应当有自己的父类加载器。这种模型的实现细节如下:
- 启动类加载器:负责加载JVM自身核心类库,如rt.jar等。
- 扩展类加载器:负责加载Java平台扩展类库。
- 应用类加载器:负责加载应用程序中的类。
当一个类加载器请求加载某个类时,它会首先请求其父类加载器进行加载,只有当父类加载器无法完成加载时,才自己尝试加载。
自定义类加载器
自定义类加载器允许开发者控制类的加载过程,实现一些特殊的功能,如实现模块化系统。其实现细节包括:
- 覆盖
loadClass
方法:在自定义类加载器中重写loadClass
方法,实现类的查找和加载逻辑。 - 实现类查找逻辑:根据需要,自定义类加载器可以采用文件系统、网络等途径查找类文件。
模块化系统(JPMS)
Java Platform Module System(JPMS)是Java 9引入的一个模块化系统,它允许将Java应用程序分解成多个模块,从而提高应用程序的可靠性和安全性。JPMS的实现细节如下:
- 模块定义:每个模块通过一个名为
module-info.java
的文件来定义模块的依赖关系和模块的公开API。 - 模块解析:JVM在运行时根据模块定义文件中的依赖关系解析模块之间的依赖。
- 模块加载:JVM根据模块解析结果加载所需的模块。
内存模型
JVM的内存模型包括运行时数据区和PC寄存器。
-
堆:存储几乎所有的对象实例和数组的内存区域,其实现细节包括:
- 内存分配策略:如标记-清除算法、复制算法等。
- 内存碎片处理:如整理算法、动态内存分配等。
-
栈:存储局部变量和方法调用的内存区域,其实现细节包括:
- 栈帧:每个方法调用都有自己的栈帧,包含局部变量表、操作数栈、方法返回地址等信息。
-
方法区:存储已被虚拟机加载的类信息、常量、静态变量等数据,其实现细节包括:
- 类元数据:如类名、字段、方法等信息。
- 常量池:存储编译时常量,如字符串常量、final变量等。
-
PC寄存器:用于存储当前线程所执行的字节码的地址,其实现细节包括:
- 指令指针:记录下一条要执行的指令地址。
内存溢出场景分析
内存溢出通常发生在堆空间不足时,可能导致程序崩溃。常见的内存溢出场景包括:
- 创建大量对象:如无限循环创建对象、使用递归创建对象等。
- 循环引用:如两个对象相互引用,导致垃圾回收器无法回收。
- 大对象分配:如大数组、大数据结构等。
直接内存管理
直接内存管理允许JVM直接在本地内存中分配内存,这部分内存不受堆空间的限制。其实现细节包括:
- 本地内存分配:通过
sun.misc.Unsafe
类的allocateMemory
和freeMemory
方法进行本地内存的分配和释放。 - 本地内存回收:通过调用
sun.misc.Unsafe
类的invokeCleaner
方法回收本地内存。
垃圾回收
垃圾回收是JVM自动管理内存的一种机制,它通过回收不再使用的对象来释放内存。其实现细节如下:
- GC Roots可达性分析:通过GC Roots找到所有可达对象,不可达对象被视为垃圾。
- 分代收集理论:将JVM的堆空间分为多个区域,如Young区、Old区等,以优化垃圾回收效率。
- 引用类型:包括强引用、软引用、弱引用和虚引用,它们在垃圾回收过程中有不同的作用。
- 垃圾回收算法:包括标记-清除、复制和整理算法等。
- 并发收集器:如CMS(Concurrent Mark Sweep)和G1(Garbage-First)等,可以在应用程序运行时进行垃圾回收,以减少停顿时间。
- 停顿时间控制策略:如最大停顿时间目标、响应时间目标等。
性能调优
性能调优包括JVM参数配置、内存泄漏诊断和JIT编译优化等。
- JVM参数配置:通过调整JVM参数来优化应用程序的性能,如设置堆空间大小、垃圾回收策略等。
- 内存泄漏诊断:通过工具诊断内存泄漏问题,如VisualVM、MAT等。
- JIT编译优化:JIT编译器对字节码进行优化,提高应用程序的性能。
二、Spring Boot知识体系
自动配置
Spring Boot的自动配置功能可以自动配置Spring应用程序,减少手动配置的工作量。其实现细节如下:
- @EnableAutoConfiguration原理:通过类路径下是否有某个类存在,来决定是否启用某个自动配置类。
- 条件化配置(@Conditional):允许开发者根据特定的条件来决定是否应用某些配置。
- 自定义Starter开发:自定义Starter可以方便地将Spring Boot应用与第三方库集成。
- 起步依赖:起步依赖是一组预定义的依赖,它们包含了构建和运行Spring Boot应用所需的库。
- 依赖管理机制:包括Maven的BOM文件和版本冲突解决。
- 第三方库集成模式:包括手动集成和自动集成。
Actuator
Spring Boot Actuator提供了一系列端点,用于监控和管理Spring Boot应用。其实现细节如下:
- 健康检查端点:可以用来检查应用的健康状态,如检查数据库连接是否正常、HTTP服务是否启动等。
- 度量指标收集:可以用来收集应用的性能数据,如请求响应时间、系统负载等。
- 自定义Endpoint开发:自定义Endpoint允许开发者创建自己的端点,以扩展Actuator的功能。
配置文件管理
Spring Boot使用配置文件来管理应用配置。其实现细节如下:
- 多环境配置:允许开发者为不同的环境配置不同的配置文件,如开发环境、测试环境和生产环境。
- 配置加载优先级:配置文件的加载顺序决定了配置的覆盖关系。
- 动态配置刷新:动态配置刷新允许在应用运行时刷新配置,如通过Spring Cloud Config实现。
监控与日志
Spring Boot提供了监控和日志功能。其实现细节如下:
- Micrometer集成:Micrometer是一个度量指标库,可以与Spring Boot集成,支持多种度量指标收集方式。
- Logback/SLF4J配置:Logback和SLF4J是日志框架,可以与Spring Boot集成,支持多种日志级别和输出格式。
分布式链路追踪
Spring Boot支持分布式链路追踪,可以追踪分布式系统中的请求。其实现细节如下:
- 自定义AutoConfigurationBean生命周期扩展点:自定义AutoConfigurationBean生命周期扩展点允许开发者扩展Spring Boot应用的自动配置功能。
- 响应式编程支持:Spring Boot支持响应式编程,可以使用Reactor等库来编写响应式应用。
通过以上对JVM和Spring Boot知识体系的详细描述,我们可以看到这两个技术是如何相互关联和影响的。JVM为Java应用提供了运行环境,而Spring Boot则是在这个环境中简化了应用开发和配置的过程。在实际应用中,理解这两个技术体系的知识点对于开发高性能、可维护的Java应用至关重要。
📥博主的人生感悟和目标

- 💂 博客主页: Java程序员廖志伟希望各位读者大大多多支持用心写文章的博主,现在时代变了,信息爆炸,酒香也怕巷子深,博主真的需要大家的帮助才能在这片海洋中继续发光发热,所以,赶紧动动你的小手,点波关注❤️,点波赞👍,点波收藏⭐,甚至点波评论✍️,都是对博主最好的支持和鼓励!
- 👉 开源项目: Java程序员廖志伟
- 🌥 哔哩哔哩: Java程序员廖志伟
- 🎏 个人社区: Java程序员廖志伟
- 🔖 个人微信号:
SeniorRD

📙经过多年在优快云创作上千篇文章的经验积累,我已经拥有了不错的写作技巧。同时,我还与清华大学出版社签下了四本书籍的合约,并将陆续出版。这些书籍包括了基础篇、进阶篇、架构篇的📌《Java项目实战—深入理解大型互联网企业通用技术》📌,以及📚《解密程序员的思维密码--沟通、演讲、思考的实践》📚。具体出版计划会根据实际情况进行调整,希望各位读者朋友能够多多支持!
🔔如果您需要转载或者搬运这篇文章的话,非常欢迎您私信我哦~