从源代码解读spring IOC容器

出处:http://cuishen.iteye.com/blog/243963

从源代码解读spring IOC容器

  • 博客分类:
  • j2ee
spring IOC容器(Inversion of Control container)做项目的时候经常要用到,但是好像感觉不到它的存在,因为代码里面很少用到spring,主要是写配置。但是我不得不说:spring做的确实很巧妙,这种和代码的松耦合很大的提高了代码的灵活性和可扩展性。最近手头的开发任务比较少,于是抽空看了看spring1.2.9的源代码,现在把心得贴出来和网友共享,欢迎大家批评指正。


1. spring IOC容器接口定义

org.springframework.beans.factory 这里是定义spring IOC容器接口的包,在这个包里有我们熟悉的BeanFactory

Java代码   收藏代码
  1. package org.springframework.beans.factory;  
  2.   
  3. public interface BeanFactory {  
  4.       
  5.     /** 
  6.      *这里是对FactoryBean的转义定义,如果使用bean的名字检索FactoryBean,得到的是工厂生成的对象,    
  7.      *如果需要得到工厂本身,需要转义。For example, if the bean named 
  8.      * <code>myJndiObject</code> is a FactoryBean, getting <code>&myJndiObject</code> 
  9.      * will return the factory  
  10.      */           
  11.     String FACTORY_BEAN_PREFIX = "&";     
  12.     
  13.     /** 
  14.      *这里根据bean的名字,在IOC容器中得到bean实例,这个IOC容器就是一个大的抽象工厂。 
  15.      */     
  16.     Object getBean(String name) throws BeansException;     
  17.     
  18.     /** 
  19.      *这里根据bean的名字和Class类型来得到bean实例,和上面的方法不同在于它会抛出异常:如果 
  20.      *根据名字取得的bean实例的Class类型和需要的不同的话。 
  21.      */     
  22.     Object getBean(String name, Class requiredType) throws BeansException;     
  23.     
  24.     /** 
  25.     *这里提供对bean的检索,看看是否在IOC容器有这个名字的bean 
  26.     */     
  27.     boolean containsBean(String name);     
  28.     
  29.     /** 
  30.      *这里根据bean名字得到bean实例,并同时判断这个bean是不是单例 
  31.      */    
  32.     boolean isSingleton(String name) throws NoSuchBeanDefinitionException;     
  33.     
  34.     /** 
  35.      *这里得到bean实例的Class类型  
  36.      */  
  37.     Class getType(String name) throws NoSuchBeanDefinitionException;     
  38.     
  39.     /** 
  40.      *这里得到bean的别名,如果根据别名检索,那么其原名也会被检索出来 
  41.      */     
  42.     String[] getAliases(String name);     
  43. }  


在BeanFactory里只对IOC容器的基本行为作了定义,根本不关心你的bean是怎样定义怎样加载的,就像我们只关心从这个工厂里能得到什么产品对象,至于工厂是怎么生产这些对象的,这个基本的接口不关心这些。如果要关心工厂是怎样产生对象的,应用程序需要使用具体的IOC容器实现

spring已经为我们准备了丰富的IOC容器的具体实现(当然,有兴趣的朋友也可以尝试实现自己的一套IOC容器来证明自己的实力也未尝不可),现在先让我们看看spring是怎样实现的:


2. spring IOC容器接口的实现

Java代码   收藏代码
  1. package org.springframework.beans.factory.support;  
  2.   
  3. public abstract class AbstractBeanFactory implements ConfigurableBeanFactory {  
  4.       
  5.     /**  
  6.      * 放置单例bean实例的缓存(IOC容器) 
  7.      * Cache of singletons: bean name --> bean instance  
  8.      */  
  9.     private final Map singletonCache = CollectionFactory.createLinkedMapIfPossible(16);  
  10.       
  11.     /** 
  12.      * 根据bean名称从缓存(IOC容器)中获得bean实例,如果缓存中没有,则根据bean的定义 
  13.      * 信息造bean的实例,如果是单例,就放进缓存(IOC容器) 
  14.      */  
  15.     public Object getBean(String name, Class requiredType, Object[] args) throws BeansException {  
  16.         String beanName = transformedBeanName(name);  
  17.         Object bean = null;  
  18.   
  19.         // 在缓存中根据名字查找bean实例.  
  20.         Object sharedInstance = null;  
  21.         synchronized (this.singletonCache) {  
  22.             sharedInstance = this.singletonCache.get(beanName);  
  23.         }  
  24.         if (sharedInstance != null) {  
  25.             ...  
  26.             // 如果容器里找的到,则从缓存返回bean  
  27.             bean = getObjectForSharedInstance(name, sharedInstance);  
  28.         } else {  
  29.             ...  
  30.             // Check if bean definition exists in this factory.  
  31.             // 如果当前BeanFactory里没有bean定义信息,则去ParentBeanFactory  
  32.             // 里查找  
  33.             if (getParentBeanFactory() != null && !containsBeanDefinition(beanName)) {  
  34.                 // Not found -> check parent.  
  35.                 if (getParentBeanFactory() instanceof AbstractBeanFactory) {  
  36.                     // Delegation to parent with args only possible for AbstractBeanFactory.  
  37.                     return ((AbstractBeanFactory) getParentBeanFactory()).getBean(name, requiredType,   
  38.   
  39. args);  
  40.                 }  
  41.                 else if (args == null) {  
  42.                     // No args -> delegate to standard getBean method.  
  43.                     return getParentBeanFactory().getBean(name, requiredType);  
  44.                 }  
  45.                 else {  
  46.                     ...  
  47.                 }  
  48.             }  
  49.             // 获得bean定义信息  
  50.             RootBeanDefinition mergedBeanDefinition = getMergedBeanDefinition(beanName, false);  
  51.             checkMergedBeanDefinition(mergedBeanDefinition, beanName, requiredType, args);  
  52.   
  53.             // Create bean instance.  
  54.             if (mergedBeanDefinition.isSingleton()) {  
  55.                 synchronized (this.singletonCache) {  
  56.                     // Re-check singleton cache within synchronized block.  
  57.                     sharedInstance = this.singletonCache.get(beanName);  
  58.                     if (sharedInstance == null) {  
  59.                         ...   
  60.                         this.currentlyInCreation.add(beanName);  
  61.                         try {  
  62.                             // 根据bean定义信息造bean的实例  
  63.                             sharedInstance = createBean(beanName, mergedBeanDefinition, args);  
  64.                             // 将bean实例放入缓存(IOC容器)  
  65.                             addSingleton(beanName, sharedInstance);  
  66.                         }  
  67.                         catch (BeansException ex) {  
  68.                             ...   
  69.                         }  
  70.                         finally {  
  71.                             this.currentlyInCreation.remove(beanName);  
  72.                         }  
  73.                     }  
  74.                 }  
  75.                 bean = getObjectForSharedInstance(name, sharedInstance);  
  76.             }  
  77.             else {  
  78.                 // 如果不是单例模式 just create a new instance.  
  79.                 bean = createBean(beanName, mergedBeanDefinition, args);  
  80.             }  
  81.         }  
  82.         ...  
  83.         return bean;  
  84.     }  
  85.   
  86.     /** 
  87.      * 抽象方法,在子类中实现 
  88.      */  
  89.     protected abstract Object createBean(  
  90.             String beanName, RootBeanDefinition mergedBeanDefinition, Object[] args) throws   
  91.   
  92. BeanCreationException;  
  93.   
  94.     /** 
  95.      * 在缓存中注册bean实例 
  96.      */  
  97.     public void registerSingleton(String beanName, Object singletonObject) throws BeanDefinitionStoreException {  
  98.         Assert.hasText(beanName, "Bean name must not be empty");  
  99.         Assert.notNull(singletonObject, "Singleton object must not be null");  
  100.         synchronized (this.singletonCache) {  
  101.             Object oldObject = this.singletonCache.get(beanName);  
  102.             if (oldObject != null) {  
  103.                 ...   
  104.             }  
  105.             addSingleton(beanName, singletonObject);  
  106.         }  
  107.     }  
  108.   
  109.     /** 
  110.      * 在缓存中注册bean实例 
  111.      */  
  112.     protected void addSingleton(String beanName, Object singletonObject) {  
  113.         Assert.hasText(beanName, "Bean name must not be empty");  
  114.         Assert.notNull(singletonObject, "Singleton object must not be null");  
  115.         synchronized (this.singletonCache) {  
  116.             this.singletonCache.put(beanName, singletonObject);  
  117.         }  
  118.     }  
  119.   
  120. }  


AbstractBeanFactory实现了BeanFactory接口里的getBean()方法,做为抽象的父类为所有继承它的子类提供getBean()的模板服务,getBean()方法是根据bean的名称在缓存--AbstractBeanFactory#singletonCache(IOC容器)里查找其实例,如果找不到则根据用户的配置文件里的bean定义信息(spring背后有一套功能十分强大的xml文件解析工具来完成bean定义文件的解析,有兴趣的朋友可以看看org.springframework.beans.factory.xml.XmlBeanDefinitionReader和org.springframework.beans.factory.xml.DefaultXmlBeanDefinitionParser,解析好后会将bean定义信息放入缓存,限于篇幅这里不再赘述)造bean实例,如果该bean是单例模式,则同时放进缓存---AbstractBeanFactory#singletonCache。getBean()是IOC容器的核心方法。在getBean()里用到了createBean()方法,顾名思义--造bean实例的方法,该方法在子类中得到了实现,现在我们看看子类中到底是怎样createBean的。

Java代码   收藏代码
  1. package org.springframework.beans.factory.support;  
  2.   
  3. public abstract class AbstractAutowireCapableBeanFactory extends AbstractBeanFactory implements AutowireCapableBeanFactory {  
  4.       
  5.     /** 
  6.      * 造bean对象 
  7.      */  
  8.     protected Object createBean(String beanName, RootBeanDefinition mergedBeanDefinition, Object[] args)  
  9.             throws BeanCreationException {  
  10.   
  11.         // 实例化并初始化当前bean所依赖的所有bean.  
  12.         if (mergedBeanDefinition.getDependsOn() != null) {  
  13.             for (int i = 0; i < mergedBeanDefinition.getDependsOn().length; i++) {  
  14.                 getBean(mergedBeanDefinition.getDependsOn()[i]);  
  15.             }  
  16.         }  
  17.         ...  
  18.         Object bean = null;  
  19.   
  20.         // Give BeanPostProcessors a chance to return a proxy instead of the target bean instance.  
  21.         if (mergedBeanDefinition.hasBeanClass()) {  
  22.             bean = applyBeanPostProcessorsBeforeInstantiation(mergedBeanDefinition.getBeanClass(), beanName);  
  23.             if (bean != null) {  
  24.                 return bean;  
  25.             }  
  26.         }  
  27.   
  28.         BeanWrapper instanceWrapper = null;  
  29.         Object originalBean = null;  
  30.         ...   
  31.         try {  
  32.             ...   
  33.             if (mergedBeanDefinition.getFactoryMethodName() != null)  {  
  34.                 //反射factoryBean的工厂方法  
  35.                 instanceWrapper = instantiateUsingFactoryMethod(beanName, mergedBeanDefinition, args);  
  36.             }  
  37.             else if (mergedBeanDefinition.getResolvedAutowireMode() == RootBeanDefinition.AUTOWIRE_CONSTRUCTOR    
  38.   
  39.             || mergedBeanDefinition.hasConstructorArgumentValues() )  {  
  40.                 //实例化bean的方法  
  41.                 instanceWrapper = autowireConstructor(beanName, mergedBeanDefinition);  
  42.             }  
  43.             else {  
  44.                 //实例化bean的方法  
  45.                 // No special handling: simply use no-arg constructor.  
  46.                 instanceWrapper = instantiateBean(beanName, mergedBeanDefinition);  
  47.             }  
  48.             bean = instanceWrapper.getWrappedInstance();  
  49.   
  50.             // Eagerly cache singletons to be able to resolve circular references  
  51.             // even when triggered by lifecycle interfaces like BeanFactoryAware.  
  52.             if (isAllowCircularReferences() && isSingletonCurrentlyInCreation(beanName)) {  
  53.                 ...   
  54.                 addSingleton(beanName, bean);  
  55.             }  
  56.   
  57.             ...  
  58.             originalBean = bean;  
  59.             bean = applyBeanPostProcessorsBeforeInitialization(bean, beanName);  
  60.             // 调用bean实例里的init方法  
  61.             invokeInitMethods(beanName, bean, mergedBeanDefinition);  
  62.             bean = applyBeanPostProcessorsAfterInitialization(bean, beanName);  
  63.         }  
  64.         catch (BeanCreationException ex) {  
  65.             ...   
  66.         }  
  67.   
  68.         // Register bean as disposable, and also as dependent on specified "dependsOn" beans.  
  69.         registerDisposableBeanIfNecessary(beanName, originalBean, mergedBeanDefinition);  
  70.   
  71.         return bean;  
  72.     }  
  73.   
  74.     /** 
  75.      * 反射factoryBean里的工厂方法,实现依赖注入 
  76.      */  
  77.     protected BeanWrapper instantiateUsingFactoryMethod(  
  78.             String beanName, RootBeanDefinition mergedBeanDefinition, Object[] explicitArgs) throws   
  79.   
  80. BeansException {  
  81.         ...   
  82.         BeanWrapperImpl bw = new BeanWrapperImpl();  
  83.         initBeanWrapper(bw);  
  84.         ...  
  85.         Object beanInstance = this.instantiationStrategy.instantiate(  
  86.                 mergedBeanDefinition, beanName, this, factoryBean, factoryMethodToUse, argsToUse);  
  87.         ...  
  88.         bw.setWrappedInstance(beanInstance);  
  89.         return bw;  
  90.     }  
  91.   
  92.     /** 
  93.      * 匹配bean构造方法来实例化bean 
  94.      */  
  95.     protected BeanWrapper autowireConstructor(String beanName, RootBeanDefinition mergedBeanDefinition)  
  96.             throws BeansException {  
  97.         ...  
  98.         BeanWrapperImpl bw = new BeanWrapperImpl();  
  99.         initBeanWrapper(bw);  
  100.         ...  
  101.         Object beanInstance = this.instantiationStrategy.instantiate(  
  102.                 mergedBeanDefinition, beanName, this, constructorToUse, argsToUse);  
  103.         bw.setWrappedInstance(beanInstance);  
  104.         ...  
  105.         return bw;  
  106.     }  
  107.     /** 
  108.      * 用bean的默认构造方法造bean实例 
  109.      */  
  110.     protected BeanWrapper instantiateBean(String beanName, RootBeanDefinition mergedBeanDefinition)  
  111.             throws BeansException {  
  112.   
  113.         Object beanInstance = getInstantiationStrategy().instantiate(mergedBeanDefinition, beanName, this);  
  114.         BeanWrapper bw = new BeanWrapperImpl(beanInstance);  
  115.         initBeanWrapper(bw);  
  116.         return bw;  
  117.     }  
  118. }  


其实create bean的过程就是通过bean的定义信息反射bean实例的过程。真正用反射造对象的代码这里没有体现出来,我们注意到了BeanWrapper仅仅是bean实例的包装类,不涉及到造对象的代码;instantiateUsingFactoryMethod()、autowireConstructor()和instantiateBean()方法里都用到了实例化策略类里面的方法--instantiate(),毫无疑问反射对象的代码就应该在instantiate()里面,现在就让我们来揭开实例化策略类的神秘面纱。

Java代码   收藏代码
  1. package org.springframework.beans.factory.support;  
  2.   
  3. public class SimpleInstantiationStrategy implements InstantiationStrategy {  
  4.       
  5.     public Object instantiate(  
  6.             RootBeanDefinition beanDefinition, String beanName, BeanFactory owner) {  
  7.   
  8.         // Don't override the class with CGLIB if no overrides.  
  9.         if (beanDefinition.getMethodOverrides().isEmpty()) {  
  10.             // 调用BeanUtils的静态方法实例化bean  
  11.             return BeanUtils.instantiateClass(beanDefinition.getBeanClass());  
  12.         }  
  13.         else {  
  14.             // Must generate CGLIB subclass.  
  15.             // 抛异常"Method Injection not supported in SimpleInstantiationStrategy"  
  16.             return instantiateWithMethodInjection(beanDefinition, beanName, owner);  
  17.         }  
  18.     }  
  19.   
  20.     public Object instantiate(  
  21.             RootBeanDefinition beanDefinition, String beanName, BeanFactory owner,  
  22.             Constructor ctor, Object[] args) {  
  23.   
  24.         if (beanDefinition.getMethodOverrides().isEmpty()) {  
  25.             // 调用BeanUtils的静态方法实例化bean  
  26.             return BeanUtils.instantiateClass(ctor, args);  
  27.         }  
  28.         else {  
  29.             return instantiateWithMethodInjection(beanDefinition, beanName, owner, ctor, args);  
  30.         }  
  31.     }  
  32.   
  33.     public Object instantiate(  
  34.             RootBeanDefinition beanDefinition, String beanName, BeanFactory owner,  
  35.             Object factoryBean, Method factoryMethod, Object[] args) {  
  36.   
  37.         try {  
  38.             // It's a static method if the target is null.  
  39.             if (!Modifier.isPublic(factoryMethod.getModifiers()) ||  
  40.                     !Modifier.isPublic(factoryMethod.getDeclaringClass().getModifiers())) {  
  41.                 // 如果方法不是公有方法,则修改它的访问权限  
  42.                 factoryMethod.setAccessible(true);  
  43.             }  
  44.             // 用反射调用factoryBean实例中的方法  
  45.             return factoryMethod.invoke(factoryBean, args);  
  46.         }  
  47.         catch (IllegalArgumentException ex) {  
  48.         ...  
  49.         }  
  50.     }  
  51. }  


原来一部分实例化bean的代码放到BeanUtils.instantiateClass()方法里了,我们现在来看看BeanUtils类

Java代码   收藏代码
  1. package org.springframework.beans;  
  2.   
  3. public abstract class BeanUtils {  
  4.     /** 
  5.      * 实例化带默认构造方法的bean 
  6.      */  
  7.     public static Object instantiateClass(Class clazz) throws BeanInstantiationException {  
  8.         ...  
  9.         try {  
  10.             return instantiateClass(clazz.getDeclaredConstructor((Class[]) null), null);  
  11.         }  
  12.         ...  
  13.     }  
  14.   
  15.     /** 
  16.      * 根据构造方法实例化bean 
  17.      */  
  18.     public static Object instantiateClass(Constructor ctor, Object[] args) throws BeanInstantiationException {  
  19.         ...  
  20.         try {  
  21.             if (!Modifier.isPublic(ctor.getModifiers()) ||  
  22.                     !Modifier.isPublic(ctor.getDeclaringClass().getModifiers())) {  
  23.                 //如果是私有构造方法则修改访问权限  
  24.                 ctor.setAccessible(true);  
  25.             }  
  26.             // 反射实例  
  27.             return ctor.newInstance(args);  
  28.         }  
  29.         ...  
  30.     }  
  31. }  


从以上代码我们不难看出,spring如果遇到bean的构造方法是私有的,那么它会去修改bean的访问权限,同样可以反射出bean的对象

3. spring依赖注入(dependence injection)的实现

所谓依赖,举个例子说明,一个类Person,另一个类Car,如果Person的某个方法比如说drive,需要引用Car,则称Person类依赖于Car类,延伸到对象,这种依赖关系依然成立。这其中的依赖关系,就导致了对象Person需要负责对象Car的创建,甚至是整个生命周期的管理,而这样显然会带来耦合度高,不易维护等缺点。spring框架的依赖注入为我们提供了很好的解决方案,将Person依赖的对象Car造好,然后注入到Person中去,而无需Person自己去引用Car,这个注入的过程,由spring IOC容器来完成,无需对象去关心。

Spring提供了3种类型的依赖注入:构造函数注入(constructor injection)、setter注入(setter injection)和方法注入(method injection)。说白了就是反射factoryBean里的方法,把所依赖的对象做为参数传进去完成注入。这里提到了factoryBean的概念,这个factoryBean其实就是IOC容器管理的bean,说白了就是有依赖关系的bean,例如我们上面举的例子里面的Person类,Person需要依赖Car对象,在IOC容器中Person的实例就是一个factoryBean,Car的对象将被注入这个factoryBean

spring究竟是怎样实现依赖注入的,其实上面已经有所提到,我们现在再来仔细看看AbstractAutowireCapableBeanFactory类的instantiateUsingFactoryMethod方法

Java代码   收藏代码
  1. package org.springframework.beans.factory.support;  
  2.   
  3. public abstract class AbstractAutowireCapableBeanFactory extends AbstractBeanFactory  
  4.         implements AutowireCapableBeanFactory {  
  5.     protected BeanWrapper instantiateUsingFactoryMethod(  
  6.             String beanName, RootBeanDefinition mergedBeanDefinition, Object[] explicitArgs) throws   
  7.   
  8. BeansException {  
  9.   
  10.         ConstructorArgumentValues cargs = mergedBeanDefinition.getConstructorArgumentValues();  
  11.         ConstructorArgumentValues resolvedValues = null;  
  12.   
  13.         int minNrOfArgs = 0;  
  14.         if (explicitArgs == null) {  
  15.             // 如果没有工厂方法的参数直接传入,我们将从bean definition中得到  
  16.             resolvedValues = new ConstructorArgumentValues();  
  17.             minNrOfArgs = resolveConstructorArguments(beanName, mergedBeanDefinition, cargs, resolvedValues);  
  18.         }  
  19.         else {  
  20.             minNrOfArgs = explicitArgs.length;  
  21.         }  
  22.   
  23.         boolean isStatic = true;  
  24.         Class factoryClass = null;  
  25.         Object factoryBean = null;  
  26.   
  27.         if (mergedBeanDefinition.getFactoryBeanName() != null) {  
  28.             // 获得factoryBean的实例  
  29.             factoryBean = getBean(mergedBeanDefinition.getFactoryBeanName());  
  30.             factoryClass = factoryBean.getClass();  
  31.             isStatic = false;  
  32.         }  
  33.         else {  
  34.             // It's a static factory method on the bean class.  
  35.             factoryClass = mergedBeanDefinition.getBeanClass();  
  36.         }  
  37.   
  38.         BeanWrapperImpl bw = new BeanWrapperImpl();  
  39.         initBeanWrapper(bw);  
  40.   
  41.         // 尝试调用factoryBean里的方法,如果这个工厂方法里的参数和得到的参数匹配  
  42.         Method[] candidates = factoryClass.getMethods();  
  43.   
  44.         Method factoryMethodToUse = null;  
  45.         Object[] argsToUse = null;  
  46.         int minTypeDiffWeight = Integer.MAX_VALUE;  
  47.         // 对工厂方法和参数做个遍历,挑出合适的方法和参数  
  48.         for (int i = 0; i < candidates.length; i++) {  
  49.             Method factoryMethod = candidates[i];  
  50.   
  51.             if (Modifier.isStatic(factoryMethod.getModifiers()) == isStatic &&  
  52.                     factoryMethod.getName().equals(mergedBeanDefinition.getFactoryMethodName()) &&  
  53.                     factoryMethod.getParameterTypes().length >= minNrOfArgs) {  
  54.   
  55.                 Class[] argTypes = factoryMethod.getParameterTypes();  
  56.                 ArgumentsHolder args = null;  
  57.   
  58.                 if (resolvedValues != null) {  
  59.                     // Resolved contructor arguments: type conversion and/or autowiring necessary.  
  60.                     try {  
  61.                         args = createArgumentArray(  
  62.                                 beanName, mergedBeanDefinition, resolvedValues, bw,   
  63.   
  64. argTypes, "factory method");  
  65.                     }  
  66.                     catch (UnsatisfiedDependencyException ex) {  
  67.                         if (logger.isDebugEnabled()) {  
  68.                             logger.debug("Ignoring factory method [" + factoryMethod + "] of   
  69.   
  70. bean '" + beanName +  
  71.                                     "': " + ex.getMessage());  
  72.                         }  
  73.                         if (i == candidates.length - 1 && factoryMethodToUse == null) {  
  74.                             throw ex;  
  75.                         }  
  76.                         else {  
  77.                             // Swallow and try next overloaded factory method.  
  78.                             continue;  
  79.                         }  
  80.                     }  
  81.                 }  
  82.   
  83.                 else {  
  84.                     // Explicit arguments given -> arguments length must match exactly.  
  85.                     if (argTypes.length != explicitArgs.length) {  
  86.                         continue;  
  87.                     }  
  88.                     args = new ArgumentsHolder(explicitArgs);  
  89.                 }  
  90.   
  91.                 int typeDiffWeight = args.getTypeDifferenceWeight(argTypes);  
  92.                 // Choose this constructor if it represents the closest match.  
  93.                 if (typeDiffWeight < minTypeDiffWeight) {  
  94.                     factoryMethodToUse = factoryMethod;  
  95.                     argsToUse = args.arguments;  
  96.                     minTypeDiffWeight = typeDiffWeight;  
  97.                 }  
  98.             }  
  99.         }  
  100.   
  101.         if (factoryMethodToUse == null) {  
  102.             throw new BeanCreationException(  
  103.                     mergedBeanDefinition.getResourceDescription(), beanName,  
  104.                     "Cannot find matching factory method '" + mergedBeanDefinition.getFactoryMethodName  
  105.   
  106. () +  
  107.                     "' on class [" + factoryClass.getName() + "]");  
  108.         }  
  109.   
  110.         // 反射factoryBean的factory method,把依赖的bean对象做为参数传入,完成注入.  
  111.         Object beanInstance = this.instantiationStrategy.instantiate(  
  112.                 mergedBeanDefinition, beanName, this, factoryBean, factoryMethodToUse, argsToUse);  
  113.         ...  
  114.         bw.setWrappedInstance(beanInstance);  
  115.         ...  
  116.         return bw;  
  117.     }  
  118. }  


现在总结下:

spring的IOC容器的功能就是把实例化对象和代码解耦,现在造对象的活完全交给spring IOC容器来做了,如果有需要,spring容器还可以把bean注入到依赖它的其它bean中,方便程序使用。我们要做的仅仅是配置好bean定义文件,并告诉spring定义文件在哪,然后在代码里getBean()就行啦!

IOC容器的载体说白了就是Map,即我们常说的缓存。在spring中IOC缓存主要分bean实例的缓存(单例)和bean定义信息的缓存

spring通过定位资源-->解析bean定义文件并缓存bean定义信息-->根据bean定义造bean实例-->如果是单例模式则把这个bean放进缓存管理,否则直接造对象-->如果有依赖关系,则反射目标bean的方法(setter方法/构造方法/普通方法)并将其依赖的bean做为参数传入,完成注入-->至此,IOC容器就建立起来了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值