一、IOC 容器:最主要是完成了完成对象的创建和依赖的管理注入等等。

  所谓控制反转,就是把原先我们代码里面需要实现的对象创建、依赖的代码,反转给容器来帮忙实现。那么必然的我们需要创建一个容器,同时需要一种描述来让容器知道需要创建的对象与对象的关系。这个描述最具体表现就是我们可配置的文件。 

   对象和对象关系怎么表示?
   可以用 xml , properties 文件等语义化配置文件表示。 

   描述对象关系的文件存放在哪里?

   可能是 classpath , filesystem ,或者是 URL 网络资源, servletContext 等。

   有了配置文件,还需要对配置文件解析。
   不同的配置文件对对象的描述不一样,如标准的,自定义声明式的,如何统一? 在内部需要有一个统一的关于对象的定义,所有外部的描述都必须转化成统一的描述定义。
   如何对不同的配置文件进行解析?需要对不同的配置文件语法,采用不同的解析器。

二、IOC体系结构

(1) BeanFactory
  Spring Bean的创建是典型的工厂模式,这一系列的Bean工厂,也即IOC容器为开发者管理对象间的依赖关系提供了很多便利和基础服务,在Spring中有许多的IOC容器的实现供用户选择和使用,其相互关系如下: 

Spring IOC实现原理_Spring


   其中BeanFactory作为最顶层的一个接口类,它定义了IOC容器的基本功能规范,BeanFactory 有三个子类:ListableBeanFactory、HierarchicalBeanFactory 和AutowireCapableBeanFactory。但是从上图中我们可以发现最终的默认实现类是 DefaultListableBeanFactory,他实现了所有的接口。那为何要定义这么多层次的接口呢?查阅这些接口的源码和说明发现,每个接口都有他使用的场合,它主要是为了区分在 Spring 内部在操作过程中对象的传递和转化过程中,对对象的数据访问所做的限制。例如 ListableBeanFactory 接口表示这些 Bean 是可列表的。HierarchicalBeanFactory 表示的是这些 Bean 是有继承关系的,也就是每个Bean 有可能有父 Bean。AutowireCapableBeanFactory 接口定义 Bean 的自动装配规则。这四个接口共同定义了 Bean 的集合、Bean 之间的关系、以及 Bean 行为.最基本的IOC容器接口BeanFactory。


public interface BeanFactory {    
      
      //对FactoryBean的转义定义,因为如果使用bean的名字检索FactoryBean得到的对象是工厂生成的对象,    
      //如果需要得到工厂本身,需要转义           
      String FACTORY_BEAN_PREFIX = "&"; 
         
      //根据bean的名字,获取在IOC容器中得到bean实例    
      Object getBean(String name) throws BeansException;    
    
     //根据bean的名字和Class类型来得到bean实例,增加了类型安全验证机制。    
      Object getBean(String name, Class requiredType) throws BeansException;    
     
     //提供对bean的检索,看看是否在IOC容器有这个名字的bean    
      boolean containsBean(String name);    
     
     //根据bean名字得到bean实例,并同时判断这个bean是不是单例    
     boolean isSingleton(String name) throws NoSuchBeanDefinitionException;    
     
     //得到bean实例的Class类型    
     Class getType(String name) throws NoSuchBeanDefinitionException;    
     
     //得到bean的别名,如果根据别名检索,那么其原名也会被检索出来    
    String[] getAliases(String name);    
     
 }


http://www.cnblogs.com/ITtangtang/p/3978349.html