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);

相关推荐
dreamxian2 小时前
微服务1 -- MybatisPlus
java·微服务·架构
糖炒栗子03262 小时前
后端异步任务编排:基于 RabbitMQ 的“中控-工人”模式
java·rabbitmq
无名-CODING2 小时前
SpringCloud 服务调用与负载均衡:OpenFeign 极简使用教程
spring·spring cloud·负载均衡
真上帝的左手2 小时前
12. 消息队列-RabbitMQ-Spring Boot 集成 RabbitMQ
spring boot·rabbitmq·java-rabbitmq
zhangren024682 小时前
Laravel5.x版本特性全解析
android·vue.js·spring boot·mysql
Meepo_haha2 小时前
ES在SpringBoot集成使用
spring boot·elasticsearch·jenkins
SimonKing2 小时前
紧急自查!Apifox被投毒,使用者速看:你的Git、SSH、云密钥可能已泄露
java·后端·程序员
Yupureki2 小时前
《Linux系统编程》18.线程概念与控制
java·linux·服务器·c语言·jvm·c++
帅得不敢出门2 小时前
Android Framework中调用由java编译成的jar接口
android·java·framework·jar