1,Spring的IOC
IOC(控制反转:Inverseof Control)是Spring容器的核心,AOP、声明式事务等功能都是以IOC作为基础展开的。控制反转的含义是:调用类对某一接口实现类的依赖关系由第三方(容器或者协作类)注入,以移除调用类对某一接口实现类的依赖。所以IOC的原理也被人叫做“依赖注入”。
2,IOC的类型
1) 构造函数注入:在构造函数中注入,我们通过调用类的构造函数,将接口实现类通过构造函数变量传入。
2) 属性注入:通过Setter方法完成调用类所需的依赖的注入。
3) 接口的注入:接口的注入需要额外声明一个接口,但是这种依赖注入的方式和属性注入的本质并无区别,所以不建议使用。
3,Spring容器完成依赖注入
Spring容器通过配置文件或注解描述类和类之间的依赖关系,自动完成类的初始化和依赖注入工作,这样就让开发者从这些底层实现类的实例化、依赖关系装配等工作中脱离出来,专注于更有意义的业务逻辑的开发工作。
4,Java的反射
Java允许程序化的方式间接对Class进行操作,Class文件由Java的类加载器装载后,在JVM中将形成一份描述Class结构的元信息对象,通过该元信息对象可以获知Class的构造函数、成员变量、方法等类元素的反射对象,并以编程的方式通过这些反射对象对目标类对象进行操作。
5,BeanFactory和ApplicationContext
Spring通过一个配置文件描述Bean及Bean之间的依赖关系,利用Java语言的反射功能实例化Bean并建立Bean之间的依赖关系。
BeanFactory是Spring框架最核心的接口,它提供了高级IOC的配置机制。BeanFactory是Spring框架的基础设施,面向Spring本身,ApplicationContext面向使用Spring框架的使用者,几乎所有的应用场合我们都直接使用ApplicationContext而非底层的BeanFactory。
5.1BeanFactory
BeanFactory是一个类的通用工厂,他可以创建和管理各种类对象。这些可被创建和管理的对象本身并没有什么特别之处,仅是一个POJO,Spring称这些被创建和管理的Java对象为Bean。Spring中的Bean是指所有可以被Spring容器实例化并管理的Java类。
5.2ApplicationContext
ApplicationContext是由BeanFactory派生而来的,提供了更多面向实际应用的功能。在BeanFactory中很多工作需要以编程的方式实现,而在ApplicationContext则可以通过配置的方式实现。
主要实现类 | 加载方式 |
ClassPathXmlApplicationContext | 默认从类路径加载配置文件 |
FileSystemXmlApplicationContext | 默认从文件系统中加载配置文件 |
5.3 BeanFactory和ApplicationContext的区别
方式 | 初始化方式 | 加载方式 |
BeanFactory | 在初始化容器是未实例化Bean,直到第一次访问的时候才实例目标Bean | 利用java的反射机制自动识别出配置文件中定义的BeanPostProcessor、InstantiationAwareBeanPostProcessor和BeanFactoryPostProcessor,并自动将它们注册到应用的上下文中 |
ApplicationContext | 在初始化应用上下文时就实例化所有单实例的Bean,所以ApplicationContext初始化时间会比BeanFactory长一点 | 需要在代码中通过手工调用addBeanPostProcessor()方法进行注册 |
5.4 WebApplicationContext
WebApplicationContext的初始化方式和BeanFactory、ApplicationContext有所区别,因为WebApplicationContext需要ServletContext实例,也就是说它必须拥有Web容器的前提下才能完成启动工作。
Spring分别提供了用于启动Servlet和Web容器监听器:
1) ContextLoaderServlet
2) ContextloaderLisenter
两者内部都实现了启动WebApplicationContext实例的逻辑,我们只要根据Web容器的具体情况选择一个,在web.xml中完成配置就行
6,Bean生命周期接口的探讨
通过实现Spring的Bean生命周期接口对Bean进行额外的控制,虽然让Bean具有了更加细致的生命周期,但也导致了Bean和Spring绑定在一起,者违背了Spring移植推崇的“不对应用程序类做任何限制”的理念,因此推荐业务类完全POJO化,只实现自己的业务接口,不需要和某个特定框架接口相关联。可以通过<bean>的init-method和destory-method等属性配置方式为Bean指定初始化和销毁的方法,采用这种方式对Bean生命周期的控制效果和通过实现InitializingBean、DisposableBean接口所达到的效果是一样的,采用这种在<bean>中配置的方式可以使Bean不需要和特定的Spring框架接口绑定,实现框架解耦的效果。