Spring 容器启动与 Bean 创建流程

Spring 在应用启动时会按照以下步骤管理 Bean 的生命周期:

第一步:扫描与注册 Bean 定义(BeanDefinition)

Spring 启动时,首先扫描指定包路径下的所有类,识别带有 @Component@Service@Repository@Controller 等注解的类,将其解析为 BeanDefinition(包含类信息、作用域、依赖关系等元数据),并注册到 BeanFactory 中。

️ 注意:此时仅完成"图纸"的登记,尚未创建任何 Bean 实例

第二步:按依赖顺序实例化 Bean(递归创建,深度优先)

Spring 并不会一次性对所有 Bean 进行全局排序,而是采用 深度优先、递归创建 的策略:

  1. 从顶层 Bean 开始创建 (如 EmployeeController)。
  2. 在创建过程中,若发现其构造函数依赖其他 Bean(如 EmployeeService),则暂停当前 Bean 的创建,转而去创建所依赖的 Bean。
  3. EmployeeService 又依赖 EmployeeRepository,则继续递归创建 EmployeeRepository
  4. 当某个 Bean 没有依赖或其依赖已存在 时,立即实例化,并将其放入 单例缓存池(singletonObjects)
  5. 依赖创建完成后,返回上层继续完成原 Bean 的实例化。

核心机制

  • 依赖的创建是"按需触发"的,通过 getBean() 方法递归实现。
  • 已创建的 Bean 会被缓存,避免重复创建,保证单例性。
简化流程示例(伪代码):
复制代码
// 1. 扫描并注册所有 Bean 定义
Set<Class<?>> allBeans = scanAllClasses();
registerBeanDefinitions(allBeans);

// 2. 开始创建 Bean(以 Controller 为起点)
// 实际过程是递归的,而非线性排序

// 创建 EmployeeRepository(无依赖)
EmployeeRepository repo = new EmployeeRepository();
singletonPool.put("employeeRepository", repo);

// 创建 EmployeeMapper(无依赖)
EmployeeMapper mapper = new EmployeeMapperImpl();
singletonPool.put("employeeMapper", mapper);

// 创建 EmployeeService(依赖 repo)
EmployeeService service = new EmployeeServiceImpl(repo);
singletonPool.put("employeeService", service);

// 创建 EmployeeController(依赖 service 和 mapper)
EmployeeController controller = new EmployeeController(service, mapper);
singletonPool.put("employeeController", controller);

相关推荐
程序猿乐锅7 小时前
Java第十三篇:Stream流
java·笔记
林三的日常7 小时前
SpringBoot + Druid SQL Parser 解析表名、字段名(纯Java,最佳方案)
java·spring boot·sql
deviant-ART7 小时前
java stream 的 findFirst 和 findAny 踩坑点
java·开发语言·后端
青衫码上行7 小时前
【从零开始学习JVM】字符串常量池
java·jvm·学习·面试·string
历程里程碑7 小时前
55 Linux epoll高效IO实战指南
java·linux·服务器·开发语言·前端·javascript·c++
何包蛋H7 小时前
Java并发编程核心:JUC、AQS、CAS 完全指南
java·开发语言
鱼鳞_7 小时前
Java学习笔记_Day35(多线程)
java·笔记·学习
木易 士心7 小时前
MyBatis Plus 核心功能与用法
java·后端·mybatis
下次再写7 小时前
互联网大厂Java面试三轮技术问答及详解——涵盖Spring Boot与微服务
java·springboot·microservices·interview
林深时见鹿v7 小时前
《后端开发全栈工具安装踩坑指南 & 经验沉淀手册》
java·人工智能·python·oracle