
高级容器都实现了ApplicationContext功能,平常说的上下文就是高级容器
public interface ApplicationContext extends EnvironmentCapable, 
ListableBeanFactory, HierarchicalBeanFactory,
		MessageSource, ApplicationEventPublisher, 
ResourcePatternResolver {
} 
之所以叫高级容器是因为在简单容器(beanFactory)的基础上加了很多功能,继承了EnvironmentCapable接口,用于获取容器的一些启动参数,对于web容器来说,可以用Environment获取servlet的一些配置信息,继承ListableBeanFactory,说明实现类可以通过列表的方式管理bean,ResourcePatterResolver 用于获取资源,ApplicationEventPublisher用于实现监听机制等,观察者模式
ApplicationContext有以下实现:


上面两个不在Spring模块中而在Springboot 的boot模块下,在Spring中的只有AnnotationConfigApplicationContext
他们相同的一步都要调用fresh()方法,基本上可以看作是bean 的初始化方法


接口本身的方法基本上都是get打头的,只提供读取操作,但最终的实现接口都是可以实现配置的,所以需要子接口ConfigurableApplicationContext来配置

ConfigurableApplicationContext extends ApplicationContext, Lifecycle, Closeable
继承了Lifecycle,具有start ,stop方法,用于容器的生命周期的处理,ApplicationContext中有refresh方法用于启动刷新,关闭上下文的能力。

AbstractApplicationContext是高级容器中最重要的抽象类,实现了不易动的方法。
引入模板方法模式
钩子方法:可选可不选
抽象方法:必须让子类实现的方法
后续的refresh方法则是模板方法的一个非常好的实践
public void refresh() throws BeansException, IllegalStateException {
		// 给容器refresh加锁,避免容器处在refresh阶段时,容器进行了初始化或者销毁的操作
		synchronized (this.startupShutdownMonitor) {
			// 调用容器准备刷新的方法,获取容器的当时时间,同时给容器设置同步标识,具体方法
			prepareRefresh();
			//告诉子类启动refreshBeanFactory()方法,Bean定义资源文件的载入从
			//子类的refreshBeanFactory()方法启动,里面有抽象方法
			//针对xml配置,最终创建内部容器,该容器负责 Bean 的创建与管理,此步会进行BeanDefinition的注册
			ConfigurableListableBeanFactory beanFactory = obtainFreshBeanFactory();
			// 注册一些容器中需要的系统Bean.例如classloader,beanfactoryPostProcessor等
			prepareBeanFactory(beanFactory);
			try {
				//允许容器的子类去注册postProcessor  ,钩子方法
				postProcessBeanFactory(beanFactory);
				// 激活在容器中注册为bean的BeanFactoryPostProcessors
				//对于注解容器,org.springframework.context.annotation.ConfigurationClassPostProcessor#postProcessBeanDefinitionRegistry
				//方法扫描应用中所有BeanDefinition并注册到容器之中
				invokeBeanFactoryPostProcessors(beanFactory);
				// 注册拦截bean创建过程的BeanPostProcessor
				registerBeanPostProcessors(beanFactory);
				// 找到“messageSource”的Bean提供给ApplicationContext使用,
				// 使得ApplicationContext具有国际化能力。
				initMessageSource();
				// 初始化ApplicationEventMulticaster该类作为事件发布者,
				// 可以存储所有事件监听者信息,并根据不同的事件,通知不同的事件监听者。
				initApplicationEventMulticaster();
				// 预留给 AbstractApplicationContext 的子类用于初始化其他特殊的 bean,
				// 该方法需要在所有单例 bean 初始化之前调用
				// 比如Web容器就会去初始化一些和主题展示相关的Bean(ThemeSource)
				onRefresh();
				// 注册监听器(检查监听器的bean并注册它们)
				registerListeners();
				//设置自定义的类型转化器ConversionService,
				// 设置自定义AOP相关的类LoadTimeWeaverAware,
				// 清除临时的ClassLoader
				// ,实例化所有的类(懒加载的类除外)
				finishBeanFactoryInitialization(beanFactory);
				// 初始化容器的生命周期事件处理器,(默认使用DefaultLifecycleProcessor),调用扩展了SmartLifecycle接口的start方法
				// 当Spring容器加载所有bean并完成初始化之后,会接着回调实现该接口的类中对应的方法(start()方法)
				// 并发布容器刷新完毕事件ContextRefreshedEvent给对应的事件监听者
				finishRefresh();
			}
			catch (BeansException ex) {
				if (logger.isWarnEnabled()) {
					logger.warn("Exception encountered during context initialization - " +
							"cancelling refresh attempt: " + ex);
				}
				// Destroy already created singletons to avoid dangling resources.
				//销毁已创建的Bean
				destroyBeans();
				// Reset 'active' flag.
				//取消refresh操作,重置容器的同步标识
				cancelRefresh(ex);
				// Propagate exception to caller.
				throw ex;
			}
			finally {
				// 重置Spring内核中的共用的缓存,因为我们可能再也不需要单例bean的元数据了……
				resetCommonCaches();
			}
		}
	} 
 
refresh本身是一个模板方法,定义了容器启动了做什么事情


















