📕我是廖志伟,一名Java开发工程师、《Java项目实战——深入理解大型互联网企业通用技术》(基础篇)、(进阶篇)、(架构篇)清华大学出版社签约作家、Java领域优质创作者、优快云博客专家、阿里云专家博主、51CTO专家博主、产品软文专业写手、技术文章评审老师、技术类问卷调查设计师、幕后大佬社区创始人、开源项目贡献者。
📘拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、SpringBoot、SpringMVC、SpringCloud、Mybatis、Dubbo、Zookeeper),消息中间件底层架构原理(RabbitMQ、RocketMQ、Kafka)、Redis缓存、MySQL关系型数据库、 ElasticSearch全文搜索、MongoDB非关系型数据库、Apache ShardingSphere分库分表读写分离、设计模式、领域驱动DDD、Kubernetes容器编排等。不定期分享高并发、高可用、高性能、微服务、分布式、海量数据、性能调优、云原生、项目管理、产品思维、技术选型、架构设计、求职面试、副业思维、个人成长等内容。
🌾阅读前,快速浏览目录和章节概览可帮助了解文章结构、内容和作者的重点。了解自己希望从中获得什么样的知识或经验是非常重要的。建议在阅读时做笔记、思考问题、自我提问,以加深理解和吸收知识。阅读结束后,反思和总结所学内容,并尝试应用到现实中,有助于深化理解和应用知识。与朋友或同事分享所读内容,讨论细节并获得反馈,也有助于加深对知识的理解和吸收。💡在这个美好的时刻,笔者不再啰嗦废话,现在毫不拖延地进入文章所要讨论的主题。接下来,我将为大家呈现正文内容。
在深入探讨Java虚拟机(JVM)和Spring Boot知识体系之前,我们将对每个技术点进行详细的技术实现细节补充,以增强文章的专业性和技术深度。
类加载机制
类加载过程
-
加载:在类加载过程中,JVM会通过类加载器去查找并加载指定名称的类或接口的
.class文件。这个过程涉及以下几个步骤:- 类加载器首先确定类的全名(包括包名)。
- 通过类加载器中的查找逻辑,在本地文件系统、JAR文件或网络中搜索该类的定义。
- 如果找到,加载器会读取类的字节码到JVM内存中,并创建一个Class对象。
-
连接:
- 验证:确保加载的类在文件格式上是有效的,并且没有安全违规。
- 准备:为类变量分配内存,并设置默认初始值。
- 解析:将符号引用替换为直接引用,即将类、接口、字段和方法的符号引用替换为直接指向它们的指针。
-
初始化:执行类的初始化代码,包括:
- 对静态变量赋值;
- 执行静态代码块;
- 初始化类中的静态初始化器表(Initialization Table)。
双亲委派模型
双亲委派模型确保了类加载器之间的层次关系,其中每个类加载器都试图委派其父类加载器来加载类,只有当父类加载器无法加载时,才由当前类加载器自行加载。这种模型的实现通常涉及到以下步骤:
- 当前类加载器收到类加载请求后,首先询问其父类加载器是否可以处理该请求。
- 如果父类加载器可以处理,则直接由父类加载器加载;如果不能处理,则由当前类加载器尝试加载。
- 如果当前类加载器无法加载,则抛出
ClassNotFoundException。
自定义类加载器
自定义类加载器允许开发者加载特定来源或特殊需求的类。实现自定义类加载器通常需要以下步骤:
- 继承
java.lang.ClassLoader类。 - 重写
findClass方法以实现类的查找逻辑。 - 可能还需要重写
loadClass方法来控制类的加载过程。
模块化系统(JPMS)
Java Platform Module System(JPMS)引入了模块的概念,它将代码组织为模块,并提供了模块之间的隔离机制。模块的定义和加载过程涉及以下细节:
- 模块定义文件
module-info.java用于声明模块的依赖、提供的接口和公开的类。 - 模块之间的依赖通过模块路径指定,通常在文件系统的顶层目录。
- 模块之间的访问控制通过
requires、uses、provides和exports关键字来管理。
内存模型
运行时数据区
- 堆:作为垃圾回收的主要区域,堆内存的管理对性能至关重要。垃圾回收器通常采用分代收集策略,将堆分为新生代和老年代。
- 栈:每个线程都有一个栈,用于存储局部变量和方法调用栈。栈空间通常较小,因此栈溢出异常较少见。
- 方法区:方法区用于存储已被虚拟机加载的类信息、常量、静态变量等数据。方法区是垃圾回收的一部分,但通常不被视为垃圾回收的常规区域。
- PC寄存器:每个线程都有一个PC寄存器,用于指示当前执行的指令地址。
内存溢出场景分析
内存溢出的常见场景包括:
- 永久代溢出:在Java 8之前,永久代用于存储静态数据,如字符串常量池。当永久代空间不足时,可能会发生溢出。
- 堆溢出:当应用程序分配的内存超过堆的最大容量时,会发生堆溢出。
- 方法区溢出:方法区用于存储类信息、常量等,当方法区空间不足时,可能会发生溢出。
垃圾回收
垃圾回收机制包括以下关键点:
- GC Roots可达性分析:垃圾回收器通过GC Roots来追踪哪些对象是活跃的,并回收不可达的对象。
- 分代收集理论:JVM通常将内存分为新生代和老年代,不同的代采用不同的垃圾回收策略,如复制算法、标记-清除算法等。
- 引用类型:Java中的引用类型包括强引用、软引用、弱引用和虚引用,它们在垃圾回收中的处理方式不同。
- 垃圾回收算法:除了标记-清除和复制算法外,还有标记-整理算法和分代收集算法等。
- 并发收集器:如CMS和G1,它们旨在减少应用程序的停顿时间,通过并发执行垃圾回收任务来实现。
- 停顿时间控制策略:如G1的并发标记阶段和并发清理阶段,旨在最小化停顿时间。
JIT编译优化
JIT编译器通过以下步骤提高性能:
- 即时编译:JIT编译器将字节码编译成本地机器码,以执行速度更快。
- 热点检测:JIT编译器识别代码中的热点,即频繁执行的部分,并对这些部分进行优化。
- 优化技术:包括循环展开、内联、逃逸分析等。
接下来,我们将对Spring Boot知识体系中的各个技术点进行详细的技术实现细节补充。
📥博主的人生感悟和目标
- 💂 博客主页: Java程序员廖志伟希望各位读者大大多多支持用心写文章的博主,现在时代变了,信息爆炸,酒香也怕巷子深,博主真的需要大家的帮助才能在这片海洋中继续发光发热,所以,赶紧动动你的小手,点波关注❤️,点波赞👍,点波收藏⭐,甚至点波评论✍️,都是对博主最好的支持和鼓励!
- 👉 开源项目: Java程序员廖志伟
- 🌥 哔哩哔哩: Java程序员廖志伟
- 🎏 个人社区: Java程序员廖志伟
- 🔖 个人微信号:
SeniorRD
📙经过多年在优快云创作上千篇文章的经验积累,我已经拥有了不错的写作技巧。同时,我还与清华大学出版社签下了四本书籍的合约,并将陆续出版。这些书籍包括了基础篇、进阶篇、架构篇的📌《Java项目实战—深入理解大型互联网企业通用技术》📌,以及📚《解密程序员的思维密码--沟通、演讲、思考的实践》📚。具体出版计划会根据实际情况进行调整,希望各位读者朋友能够多多支持!
🔔如果您需要转载或者搬运这篇文章的话,非常欢迎您私信我哦~
470

被折叠的 条评论
为什么被折叠?



