spring IOC 核心流程分析

一、IOC 核心接口缓存

IOC 中最主要的有两个接口,一个是BeanFactory ,一个是ApplicationContext 。app

BeanFactory 做为IOC容器的顶层接口,提供了对容器bean 的一些基础操做如getBean(xxx),containsBean(xxx),isSingleton(String name),getType(String name)。ide

ApplicationContext 继承自BeanFactory接口,除了包含BeanFactory的全部功能以外,在国际化支持、资源访问(如URL和文件)、事件传播等方面进行了良好的支持。post

二、IOC 核心流程this

AbstractApplicationContext.refresh()spa

 @Override public void refresh() throws BeansException, IllegalStateException { synchronized (this.startupShutdownMonitor) { // Prepare this context for refreshing.
 prepareRefresh(); /* * 一、刷新子类BeanFactory * 二、建立Beanfactory实例 * beanFactory = new DefaultListableBeanFactory() */ ConfigurableListableBeanFactory beanFactory = obtainFreshBeanFactory(); /** 初始化 BeanFactory相关的一些配置 **/ prepareBeanFactory(beanFactory); try { //bean 工厂后置处理器 ,子类重写
 postProcessBeanFactory(beanFactory); /** 调用实现BeanFactoryProcessor接口的Bean的 beanFactoryPostProcessor方法 **/ invokeBeanFactoryPostProcessors(beanFactory); /** 注册Bean后置处理器,拦截Bean的建立 **/ registerBeanPostProcessors(beanFactory); // Initialize message source for this context.
 initMessageSource(); /** 初始化事件多播器 **/ initApplicationEventMulticaster(); // Initialize other special beans in specific context subclasses.
 onRefresh(); //将全部项目里面的ApplicationListener注册进容器
 registerListeners(); // 初始化全部剩下的单实例bean /** 一、beanFactory.preInstantiateSingletons();初始化后剩下的单实例bean 1)、获取容器中的全部Bean,依次进行初始化和建立对象 2)、获取Bean的定义信息;RootBeanDefinition 3)、Bean不是抽象的,是单实例的,是懒加载; 1)、判断是不是FactoryBean;是不是实现FactoryBean接口的Bean; 2)、不是工厂Bean。利用getBean(beanName);建立对象 0、getBean(beanName); ioc.getBean(); 一、doGetBean(name, null, null, false); 二、先获取缓存中保存的单实例Bean。若是能获取到说明这个Bean以前被建立过(全部建立过的单实例Bean都会被缓存起来) 从private final Map<String, Object> singletonObjects = new ConcurrentHashMap<String, Object>(256);获取的 三、缓存中获取不到,开始Bean的建立对象流程; 四、标记当前bean已经被建立 五、获取Bean的定义信息; 六、【获取当前Bean依赖的其余Bean;若是有按照getBean()把依赖的Bean先建立出来;】 七、启动单实例Bean的建立流程; 1)、createBean(beanName, mbd, args); 2)、Object bean = resolveBeforeInstantiation(beanName, mbdToUse);让BeanPostProcessor先拦截返回代理对象; 【InstantiationAwareBeanPostProcessor】:提早执行; 先触发:postProcessBeforeInstantiation(); 若是有返回值:触发postProcessAfterInitialization(); 3)、若是前面的InstantiationAwareBeanPostProcessor没有返回代理对象;调用4) 4)、Object beanInstance = doCreateBean(beanName, mbdToUse, args);建立Bean 1)、【建立Bean实例】;createBeanInstance(beanName, mbd, args); 利用工厂方法或者对象的构造器建立出Bean实例; 2)、applyMergedBeanDefinitionPostProcessors(mbd, beanType, beanName); 调用MergedBeanDefinitionPostProcessor的postProcessMergedBeanDefinition(mbd, beanType, beanName); 3)、【Bean属性赋值】populateBean(beanName, mbd, instanceWrapper); 赋值以前: 1)、拿到InstantiationAwareBeanPostProcessor后置处理器; postProcessAfterInstantiation(); 2)、拿到InstantiationAwareBeanPostProcessor后置处理器; postProcessPropertyValues(); =====赋值以前:=== 3)、应用Bean属性的值;为属性利用setter方法等进行赋值; applyPropertyValues(beanName, mbd, bw, pvs); 4)、【Bean初始化】initializeBean(beanName, exposedObject, mbd); 1)、【执行Aware接口方法】invokeAwareMethods(beanName, bean);执行xxxAware接口的方法 BeanNameAware\BeanClassLoaderAware\BeanFactoryAware 2)、【执行后置处理器初始化以前】applyBeanPostProcessorsBeforeInitialization(wrappedBean, beanName); BeanPostProcessor.postProcessBeforeInitialization(); 3)、【执行初始化方法】invokeInitMethods(beanName, wrappedBean, mbd); 1)、是不是InitializingBean接口的实现;执行接口规定的初始化; 2)、是否自定义初始化方法; 4)、【执行后置处理器初始化以后】applyBeanPostProcessorsAfterInitialization BeanPostProcessor.postProcessAfterInitialization(); 5)、注册Bean的销毁方法; 5)、将建立的Bean添加到缓存中singletonObjects; ioc容器就是这些Map;不少的Map里面保存了单实例Bean,环境信息。。。。; 全部Bean都利用getBean建立完成之后; 检查全部的Bean是不是SmartInitializingSingleton接口的;若是是;就执行afterSingletonsInstantiated(); */ finishBeanFactoryInitialization(beanFactory); // Last step: publish corresponding event.
 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.
 destroyBeans(); // Reset 'active' flag.
 cancelRefresh(ex); // Propagate exception to caller.
                throw ex; } finally { // Reset common introspection caches in Spring's core, since we // might not ever need metadata for singleton beans anymore...
 resetCommonCaches(); } } }

 三、总结代理

     1)、Spring容器在启动的时候,先会保存全部注册进来的Bean的定义信息;
           1)、xml注册bean;<bean>
           2)、注解注册Bean;@Service、@Component、@Bean、xxx
     2)、Spring容器会合适的时机建立这些Bean
           1)、用到这个bean的时候;利用getBean建立bean;建立好之后保存在容器中;
           2)、统一建立剩下全部的bean的时候;finishBeanFactoryInitialization();
     3)、后置处理器;BeanPostProcessor
           1)、每个bean建立完成,都会使用各类后置处理器进行处理;来加强bean的功能;
                AutowiredAnnotationBeanPostProcessor:处理自动注入
                AnnotationAwareAspectJAutoProxyCreator:来作AOP功能;
                xxx....
                加强的功能注解:
                AsyncAnnotationBeanPostProcessor
     4)、事件驱动模型;
           ApplicationListener;事件监听;
           ApplicationEventMulticaster;事件派发:
相关文章
相关标签/搜索