外观
一句话答案
BeanFactory 是基础容器(懒加载),ApplicationContext 是增强容器(预加载单例 + 事件/国际化/AOP/注解支持)。
核心要点
完整的 Bean 生命周期(14 步):
① 实例化(Instantiation)
→ 通过构造函数或工厂方法创建 Bean 实例(此时属性都是默认值)
② 属性填充(Populate Properties)
→ 依赖注入:将 @Autowired / @Value 等注解的属性值注入 Bean
③ 调用 BeanNameAware.setBeanName()
→ 如果 Bean 实现了 BeanNameAware,注入 Bean 的 id/name
④ 调用 BeanFactoryAware.setBeanFactory()
→ 如果实现了 BeanFactoryAware,注入 BeanFactory
⑤ 调用 ApplicationContextAware.setApplicationContext()
→ 如果实现了 ApplicationContextAware,注入 ApplicationContext
⑥ 调用 BeanPostProcessor.postProcessBeforeInitialization()
→ 所有 BeanPostProcessor 的前置处理(可修改 Bean)
→ ✅ AOP 代理对象在此处创建(注意:是 postProcessAfterInitialization,即第⑩步)
⑦ 调用 @PostConstruct 方法(JSR-250)
→ 标注了 @PostConstruct 的方法在此执行
⑧ 调用 InitializingBean.afterPropertiesSet()
→ 如果实现了 InitializingBean,此方法在属性注入后执行
⑨ 调用自定义 init-method
→ XML 中 init-method 或 @Bean(initMethod="...") 指定的初始化方法
⑩ 调用 BeanPostProcessor.postProcessAfterInitialization()
→ 所有 BeanPostProcessor 的后置处理
→ ✅ AOP 代理在此步骤生成(AbstractAutoProxyCreator 实现此接口)
── Bean 可以正常使用 ──
⑪ 调用 @PreDestroy 方法(容器关闭前)
⑫ 调用 DisposableBean.destroy()
⑬ 调用自定义 destroy-method记忆要点:
- AOP 代理在第⑩步(postProcessAfterInitialization)生成,不是第⑥步
- 初始化顺序:
@PostConstruct>afterPropertiesSet()>init-method - 销毁顺序:
@PreDestroy>destroy()>destroy-method
追问与易错
追问方向:
- ApplicationContext 比 BeanFactory 多什么?
- 什么时候用 BeanFactory?
- AnnotationConfigApplicationContext 流程?
易错点:
- ❌ BeanFactory 不能创建 Bean——可以只是功能少
- ❌ BeanFactory 已废弃——仍在使用
💡 记忆锚点
BeanFactory = 毛坯房(基础容器,要啥自己造,懒加载);ApplicationContext = 精装修(预加载单例+事件监听+国际化+AOP支持,拎包入住)。实际开发99%用ApplicationContext,BeanFactory是它的底层地基。