Spring 在应用启动时会按照以下步骤管理 Bean 的生命周期:
第一步:扫描与注册 Bean 定义(BeanDefinition)
Spring 启动时,首先扫描指定包路径下的所有类,识别带有 @Component、@Service、@Repository、@Controller 等注解的类,将其解析为 BeanDefinition(包含类信息、作用域、依赖关系等元数据),并注册到 BeanFactory 中。
️ 注意:此时仅完成"图纸"的登记,尚未创建任何 Bean 实例。
第二步:按依赖顺序实例化 Bean(递归创建,深度优先)
Spring 并不会一次性对所有 Bean 进行全局排序,而是采用 深度优先、递归创建 的策略:
- 从顶层 Bean 开始创建 (如
EmployeeController)。 - 在创建过程中,若发现其构造函数依赖其他 Bean(如
EmployeeService),则暂停当前 Bean 的创建,转而去创建所依赖的 Bean。 - 若
EmployeeService又依赖EmployeeRepository,则继续递归创建EmployeeRepository。 - 当某个 Bean 没有依赖或其依赖已存在 时,立即实例化,并将其放入 单例缓存池(singletonObjects)。
- 依赖创建完成后,返回上层继续完成原 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);