📕我是廖志伟,一名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程序的类型安全。类加载的过程涉及多个步骤,每个步骤都有其特定的技术实现细节:
-
加载(Loading):在加载阶段,JVM的类加载器通过查找类路径(Classpath)来定位并加载类的字节码文件。Java中有多种类加载器,包括根加载器(Bootstrap ClassLoader)、扩展加载器(Extension ClassLoader)和应用加载器(Application ClassLoader)。其中,Bootstrap ClassLoader负责加载JVM核心库,如rt.jar中的类;Extension ClassLoader负责加载JDK扩展库;Application ClassLoader负责加载应用程序中的类。
-
连接(Linking):在连接阶段,类加载器会验证类文件是否遵循Java语言规范,确保没有违反访问控制或符号引用错误。验证完成后,类加载器为类的静态变量分配内存,并设置默认值。这一步还包括解析符号引用,将符号引用替换为直接引用,使得运行时可以直接访问类的字段和方法。
-
初始化(Initialization):初始化阶段是类加载的最后一步,它负责执行类定义中的静态初始化代码块,并设置类变量。这个阶段是初始化类的关键步骤,类加载器在初始化阶段会调用类加载器的
resolveClass()
方法来解析类中的符号引用。
类加载过程
类加载过程涉及以下技术实现细节:
- 类加载器:Java类加载器负责将类的.class文件转换为Java类型。类加载器分为启动类加载器、扩展类加载器和应用程序类加载器。每个类加载器都有自己的加载路径和父类加载器。
- 类缓存:JVM使用类缓存来存储已经加载的类,避免重复加载相同的类。
- 类定义数据结构:类加载器将类定义加载到内存中时,会使用特定的数据结构来存储类信息,如方法表、字段表、属性表等。
双亲委派模型
双亲委派模型是一种安全机制,它要求子类加载器先请求其父类加载器进行类加载。这种模型防止了恶意类加载器加载非法类文件,保证了类型安全。其技术实现细节包括:
- 类加载器链:每个类加载器都有一个父类加载器,形成一个类加载器链。当子类加载器请求加载一个类时,它会首先询问父类加载器是否已经加载了这个类,如果父类加载器已经加载,则直接使用父类加载器加载的类实例;如果父类加载器没有加载,则子类加载器再尝试加载。
- 委托过程:类加载器链中的每个类加载器在委托过程中都会尝试加载请求的类,直到达到最顶层的启动类加载器。
自定义类加载器
自定义类加载器允许开发者根据特定需求控制类的加载过程。技术实现细节包括:
- 类加载器继承:自定义类加载器通常继承自
java.lang.ClassLoader
类。 - 覆盖方法:自定义类加载器需要覆盖
findClass()
方法来实现自定义的类查找逻辑。 - 类加载策略:自定义类加载器可以采用多种类加载策略,如基于文件系统、基于数据库、基于网络等。
模块化系统(JPMS)
Java Platform Module System(JPMS)通过模块的概念来组织Java代码,提高了代码的可重用性和可维护性。技术实现细节包括:
- 模块定义:每个模块通过一个模块描述文件(module-info.java)来定义模块的依赖关系、公开的包和资源等。
- 模块解析:模块解析器根据模块描述文件解析模块之间的依赖关系。
- 模块版本控制:JPMS提供了模块版本控制机制,以确保不同模块之间的一致性。
内存模型
JVM的内存模型是一个复杂的系统,它涉及到多种内存区域和寄存器。技术实现细节包括:
- 堆内存:堆内存是JVM中最大的内存区域,用于存储对象实例和数组。堆内存的管理依赖于垃圾回收器。
- 栈内存:栈内存用于存储局部变量和方法调用信息。每个线程都有自己的栈内存。
- 方法区:方法区存储类信息、常量、静态变量等。方法区是所有线程共享的。
- PC寄存器:PC寄存器用于存储当前线程正在执行的指令的地址。
内存溢出场景分析
内存溢出是JVM运行时可能出现的问题,它通常由以下原因引起:
- 动态内存分配:当程序创建大量对象实例时,如果这些对象无法被垃圾回收,就会导致内存溢出。
- 循环引用:循环引用会导致垃圾回收器无法回收引用的对象,从而造成内存泄漏。
- 内存泄漏:内存泄漏是指程序中存在无法被垃圾回收器回收的内存,它可能导致内存溢出。
垃圾回收
垃圾回收是JVM自动管理内存的重要机制,它通过回收不再使用的对象来释放内存。技术实现细节包括:
- 可达性分析:垃圾回收器通过可达性分析确定哪些对象是可达的,即这些对象仍然被程序引用。
- 分代收集:JVM将对象分为新生代和老年代,针对不同年龄段采用不同的回收策略,如复制算法和标记-清除算法。
- 引用类型:引用类型分为强引用、软引用、弱引用和虚引用,不同类型的引用对垃圾回收有不同的影响。
- 垃圾回收算法:常见的垃圾回收算法包括标记-清除、复制、标记-整理、标记-压缩等。
- 并发收集器:并发收集器如CMS(Concurrent Mark Sweep)、G1(Garbage-First)和ZGC(Z Garbage Collector)旨在减少垃圾回收的停顿时间。
Spring Boot知识体系
自动配置
Spring Boot的自动配置功能通过分析类路径下的依赖关系来自动配置应用程序。技术实现细节包括:
- 条件注解:Spring Boot使用条件注解(如
@ConditionalOnClass
、@ConditionalOnBean
)来决定是否启用某些配置。 - 自动配置器:Spring Boot使用自动配置器来简化应用程序的配置,自动配置器会根据依赖关系自动配置相关的组件。
- 条件化配置:通过条件化配置,Spring Boot可以根据不同的条件来启用或禁用某些配置,例如,根据是否安装了某个库来决定是否启用某些功能。
自定义Starter开发
自定义Starter可以简化其他开发者使用你的库的过程。技术实现细节包括:
- 起步依赖:起步依赖定义了项目所需的依赖关系,通常使用Maven或Gradle来管理。
- 依赖管理机制:使用BOM(Bill of Materials)文件来管理依赖版本,以解决版本冲突问题。
- 第三方库集成模式:Spring Boot支持多种第三方库的集成模式,如提供适配器或转换器等。
Actuator
Spring Boot Actuator提供了一系列端点,用于监控和管理应用程序。技术实现细节包括:
- 健康检查端点:健康检查端点可以用于检查应用程序的健康状态,如
/actuator/health
。 - 度量指标收集:度量指标收集可以用于收集应用程序的性能指标,如内存使用率、CPU使用率等。
- 自定义Endpoint开发:自定义Endpoint开发允许开发者根据需求扩展Spring Boot的端点。
配置文件管理
Spring Boot使用配置文件来管理应用程序的配置。技术实现细节包括:
- 多环境配置:通过配置文件名称的不同,为不同环境提供不同的配置,如
application-dev.properties
和application-prod.properties
。 - 配置加载优先级:Spring Boot会根据配置文件的优先级来加载配置,通常开发环境的配置文件优先级更高。
- 动态配置刷新:Spring Boot允许在运行时动态刷新配置,这对于开发、测试和生产环境都非常有用。
监控与日志
Spring Boot提供了多种监控和日志解决方案。技术实现细节包括:
- Micrometer集成:Micrometer是一个开源的监控和度量集成框架,它支持多种监控工具,如Prometheus、Graphite和InfluxDB。
- Logback/SLF4J配置:Spring Boot使用Logback作为日志框架,它提供了丰富的配置选项,如日志级别、日志格式和日志输出位置。
分布式链路追踪扩展机制
Spring Boot支持分布式链路追踪,允许开发者追踪分布式系统中的请求路径。技术实现细节包括:
- 自定义AutoConfigurationBean生命周期扩展点:自定义AutoConfigurationBean生命周期扩展点允许开发者自定义AutoConfigurationBean的生命周期。
- 响应式编程支持:Spring Boot支持响应式编程,允许开发者使用Reactor等库来编写异步代码。
通过以上对JVM和Spring Boot知识体系的详细描述,我们可以看到这两个技术是如何相互关联和影响的。JVM作为Java程序运行的环境,为Spring Boot提供了基础,而Spring Boot则构建在JVM之上,提供了简化Java应用开发的方式。掌握这两个技术,对于Java开发者来说至关重要。
📥博主的人生感悟和目标

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

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