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

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

JVM知识体系详解
类加载机制
Java虚拟机(JVM)的类加载机制是实现Java动态性、灵活性和安全性的关键。它通过类加载器将类文件(.class文件)加载到JVM中,并确保每个类只被加载一次,即保证类加载的唯一性。
-
加载(Loading):类加载器负责将类文件加载到JVM中,这一过程涉及到文件系统的查找、读取和字节码的解析。加载过程中,类加载器会检查类的文件格式是否符合JVM规范,并创建一个
Class
对象来表示这个类。 -
验证(Verification):验证过程是连接阶段的第一个子阶段,其目的是确保加载的类信息符合JVM规范。验证器会检查类文件的结构、字节码、符号引用等,以确保它们没有违反JVM的约束。
-
准备(Preparation):为类变量分配内存,并设置默认初始值。对于基本数据类型,类变量初始值是0、false或null;对于对象类型的类变量,初始值是null。
-
解析(Resolution):将符号引用转换为直接引用。这一步骤涉及到解析类、接口、字段和方法的符号引用,将其替换为指向运行时表示的指针或偏移量。
-
初始化(Initialization):为类的静态变量赋予初始值,执行静态代码块。初始化过程是类加载的最后阶段,它确保类的静态变量被初始化为正确的值,并执行静态初始化代码块。
类加载过程
类加载过程可以分为加载、连接和初始化三个阶段:
- 加载:查找并加载类的.class文件到JVM中,生成Class对象。
- 连接:包括验证、准备和解析三个步骤,确保类在运行时符合JVM规范。
- 初始化:执行类的初始化代码,包括静态代码块和静态变量赋值。
双亲委派模型
双亲委派模型是JVM中的一种类加载策略,它要求除了顶层的启动类加载器外,其余的类加载器都委托其父类加载器进行加载。这种模型确保了类型安全,防止同名类的冲突。
在双亲委派模型中,如果子类加载器需要加载一个类,它会首先请求其父类加载器加载该类。只有当父类加载器无法加载该类时,子类加载器才会尝试从自己的资源中加载该类。
自定义类加载器
自定义类加载器允许开发者控制类的加载过程,实现特定的类加载逻辑。通过继承ClassLoader
类或实现ClassLoader
接口,可以创建自定义类加载器。
自定义类加载器可以用于实现不同的类加载策略,例如,实现热部署功能,允许在运行时动态加载和卸载类。
模块化系统(JPMS)
Java Platform Module System(JPMS)是Java 9引入的一种模块化系统,它允许将Java应用程序分解为多个模块,以提高性能和安全性。
模块化系统通过模块描述文件(module-info.java)来定义模块的依赖关系和模块的接口。模块化系统能够减少类的查找时间,提高类加载效率,同时增强了代码的安全性。
内存模型
JVM的内存模型包括以下数据区域:
- 堆(Heap):存储所有类实例和数组对象。堆内存是动态分配的,JVM的垃圾回收主要在堆上进行。
- 栈(Stack):存储局部变量和方法调用栈。栈内存是线程私有的,每个线程都有自己的栈内存。
- 方法区(Method Area):存储已被虚拟机加载的类信息、常量、静态变量等数据。方法区是所有线程共享的。
- PC寄存器:用于存储当前线程所执行的指令的地址。PC寄存器是线程私有的。
内存溢出场景分析
内存溢出是指JVM的内存使用超出预定限制。常见的内存溢出场景包括:
- 堆溢出:堆内存不足,无法分配新的对象。可以通过调整JVM堆内存大小(
-Xmx
和-Xms
参数)来解决这个问题。 - 栈溢出:栈内存不足,无法创建新的栈帧。可以通过调整JVM栈内存大小(
-Xss
参数)来解决这个问题。 - 方法区溢出:方法区内存不足,无法加载新的类。可以通过调整JVM方法区大小(
-XX:MaxMetaspaceSize
参数)来解决这个问题。
垃圾回收
垃圾回收(GC)是JVM自动管理内存的一种机制。它通过回收不再使用的对象来释放内存。
- GC Roots可达性分析:从GC Roots开始,向上遍历对象图,确定哪些对象是可达的。GC Roots通常包括静态变量、常量池、线程栈等。
- 分代收集理论:将对象分为新生代(Young)和老年代(Old),分别采用不同的回收策略。新生代采用复制算法,老年代采用标记-清除或标记-整理算法。
- 引用类型:包括强引用、软引用、弱引用和虚引用,它们在垃圾回收中的角色不同。强引用是最常见的引用类型,弱引用、软引用和虚引用在垃圾回收时可能会被回收。
垃圾回收算法
常见的垃圾回收算法包括:
- 标记-清除(Mark-Sweep):分为标记和清除两个阶段。标记阶段遍历所有对象,将可达对象标记为存活;清除阶段回收未被标记的对象。
- 复制(Copying):将内存分为两个相等的区域,每次只使用其中一个区域。当区域满时,将存活对象复制到另一个区域,并清空旧区域。
- 整理(Mark-Compact):在标记-清除算法的基础上,将存活对象移动到内存的一端,清理掉内存碎片。
并发收集器
并发收集器允许GC与应用程序同时运行,减少停顿时间。常见的并发收集器包括:
- CMS(Concurrent Mark Sweep):适用于响应时间敏感的场景。CMS收集器在标记阶段与应用程序并发运行,在清除阶段暂停应用程序。
- G1(Garbage-First):适用于大内存场景。G1收集器将堆内存划分为多个区域,优先回收垃圾收集价值高的区域。
- ZGC(Z Garbage Collector):适用于小内存场景。ZGC收集器通过压缩指针和并发标记-整理算法实现低延迟的垃圾回收。
停顿时间控制策略
停顿时间控制策略旨在减少GC导致的停顿时间。常见的策略包括:
- 自适应大小调整:根据GC性能动态调整堆大小,以减少停顿时间。
- 并发GC:允许GC与应用程序同时运行,减少停顿时间。
性能调优
性能调优包括以下方面:
- JVM参数配置:通过调整JVM参数来优化性能,如
-Xms
、-Xmx
、-Xss
、-XX:MaxMetaspaceSize
等。 - 内存泄漏诊断:通过工具检测和修复内存泄漏。
JIT编译优化
JIT编译器可以将Java字节码编译成本地机器码,提高程序执行效率。JIT编译器通过静态分析、动态优化等技术,生成高效的机器码。
Spring Boot知识体系详解
自动配置
Spring Boot的自动配置功能可以自动配置Spring应用程序。它基于以下原理:
- @EnableAutoConfiguration:通过注解启用自动配置。当在Spring Boot应用程序中添加
@SpringBootApplication
注解时,Spring Boot会自动查找并启用相关的自动配置类。 - 条件化配置(@Conditional):根据特定条件启用或禁用配置。例如,当应用程序中存在某个类时,才会启用相应的自动配置。
自定义Starter开发
自定义Starter可以帮助开发者快速集成第三方库。开发自定义Starter包括以下步骤:
- 创建Maven项目。
- 添加依赖。
- 编写自动配置类。
起步依赖
起步依赖(Starter Dependency)是Spring Boot提供的一组预定义的依赖,用于简化项目搭建。例如,spring-boot-starter-web
提供了Web开发所需的依赖。
依赖管理机制
依赖管理机制包括以下方面:
- BOM(Bill of Materials)文件:用于定义项目依赖的版本。BOM文件可以确保项目中所有依赖的版本一致性。
- 版本冲突解决:通过依赖树分析解决版本冲突。Spring Boot使用Apache Maven的依赖管理机制来处理版本冲突。
第三方库集成模式
Spring Boot支持多种第三方库集成模式,包括:
- 自动配置:通过自动配置类集成第三方库。
- 配置属性:通过配置文件集成第三方库。
Actuator
Spring Boot Actuator提供了一系列端点,用于监控和管理应用程序。常见的端点包括:
- 健康检查:检查应用程序的健康状态。开发者可以通过
/health
端点获取应用程序的健康信息。 - 度量指标:收集应用程序的性能数据。开发者可以通过
/metrics
端点获取应用程序的度量指标。
配置文件管理
Spring Boot支持多环境配置,通过以下方式:
- 多环境配置文件:
application-{profile}.yml
,例如application-dev.yml
和application-prod.yml
。开发者可以根据不同的环境创建不同的配置文件。 - 配置加载优先级:根据配置文件的位置和名称确定优先级。Spring Boot会按照以下顺序加载配置文件:
application.yml
application-{profile}.yml
(例如application-dev.yml
)application.yml
- 动态配置刷新:支持动态刷新配置。开发者可以使用Spring Cloud Config等工具实现动态配置刷新。
监控与日志
Spring Boot提供了多种监控和日志解决方案,包括:
- Micrometer:用于集成各种监控工具。Micrometer支持多种监控工具,如Prometheus、Grafana等。
- Logback/SLF4J:用于日志记录。Spring Boot默认使用Logback作为日志框架,并提供SLF4J作为日志门面。
分布式链路追踪
Spring Boot支持分布式链路追踪,例如:
- Zipkin:用于追踪分布式系统中的请求。Zipkin可以将分布式系统中的请求链路信息记录下来,方便开发者分析和调试。
扩展机制
Spring Boot提供了多种扩展机制,包括:
- 自定义AutoConfigurationBean:通过实现
AutoConfigure
接口自定义自动配置类。 - 生命周期扩展点:通过实现
Lifecycle
接口自定义生命周期事件。
响应式编程支持
Spring Boot支持响应式编程,例如:
- WebFlux:用于构建非阻塞的Web应用程序。WebFlux允许开发者使用异步编程模型来构建高性能的Web应用程序。
📥博主的人生感悟和目标

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

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