深入理解java:4.2. 框架编程之Spring框架的设计理念

Posted 张俊鸿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了深入理解java:4.2. 框架编程之Spring框架的设计理念相关的知识,希望对你有一定的参考价值。

什么是Spring呢?

Spring是为了解决企业应用开发的复杂性而创建的一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。

Spring优点

       简单了解Spring之后,我们看一下Spring的优点。

1、方便解耦,简化开发。
2、AOP编程的支持。
3、声明式事务的支持。
4、方便程序的测试。。
5、方便集成各种优秀框架。

6、降低Java EE API的使用难度。

Spring的骨骼架构

Spring总共有十几个组件,但是真正核心组件只有三个:CoreContextBeans

没有它们就不可能有AOPWeb、ORM等上层的扩展的特性功能。

Spring的设计理念

Spring的三个核心组件,Bean比作一场演出中的演员的话,那Context就是这场演出的舞台背景,而Core应该就是演出的道具了。

三个核心组件中最核心那就非Beans组件莫属了,因为Spring就是面向Bean的编程(BOP,Bean Oriented Programming),Bean在Spring 中才是真正的主角。Bean在Spring中作用就像Object对OOP的意义一样。

Bean包装的是Object,而Object必然有数据,如何给这些数据提供生存环境就是Context要解决的问题,对Context来说他就是要发现每个Bean之间的关系,为它们建立这种关系并且要维护好 这种关系。

Core就是发现、建立和维护每 个Bean之间的关系所需要的一些列的工具,从这个角度看来,Core这个组件叫Util更能让你理解。

Bean组件

org.springframework.beans包下,这个包下的所有类主要解决了三件事:对Bean 的创建、Bean的定义、Bean的解析

对Spring的使用者来说唯一需要关心的就是Bean的创建,其他两个由Spring在内部帮你完成了。

 

Bean的创建时典型的工厂模式,他的顶级接口是BeanFactory,有三个子类:可列表的ListableBeanFactory、有继承关系的HierarchicalBeanFactory和自动装配的Autowire Capable BeanFactory。

最终的默认实现类是DefaultListableBeanFactory,他实 现了所有的接口。

Bean的定义主要有BeanDefinition描述,就是完整的描述了在Spring的配置文件中你定义的节点中所有的信息,包括各种子节点。

当Spring成功解析你定义的一个节点后,在Spring的内部他就被转化 成BeanDefinition对象。

Bean的解析过程非常复杂,功能被分的很细,因为这里需要被扩展的地方很多,Bean的解析主要就是对Spring配置文件的解析。

Context组件

org.springframework.context包下,Context组件在Spring中的作用,实际上就是给Spring提供一个运行时的环境。

ApplicationContext是Context组件的顶级父类,ApplicationContext继承了BeanFactory,这也说明了Spring容器中运行的主体对象是Bean,

另外ApplicationContext继承了ResourceLoader接口,使得ApplicationContext可以访 问到任何外部资源,这里将会使用到Core组建。

ApplicationContext的子类主要有ConfigurableApplicationContext,表示该Context是可修改的,其下面又有一个子类,可更新的Context,即 AbstractRefreshableApplicationContext类。

ApplicationContext的子类还有一个WebApplicationContext,就是为web准备的Context。他可以直接访问到ServletContext,通常情况下,这个接口使用的少。

Core组件

包含了很多的关键类,其中一个重要组成部分就是定义了资源的访问方式

Resource接口封装了各种可能的资源类型,也就是对使用者来说屏蔽了文件类型的不同。

Resource 接口继承了InputStreamSource接口,这个接口中有个getInputStream方法,返回的是InputStream类。这样所有的资源都被可以通过InputStream这个类来获取,所以也屏蔽了资源的提供者

另外还有一 个,资源的加载者要统一,这个任务是由ResourceLoader接口完成,他屏蔽了所有的资源加载者的差异,只需要实现这个接口就可以加载所有的资源, 他的默认实现DefaultResourceLoader

如何创建BeanFactory工厂

Ioc容器实际上就是Context组件结合其他两个组件共同构建了一个Bean关系网,如何构建这个关系网?

构建的入口就在AbstractApplicationContext类的refresh方法中。

清单1.AbstractApplicationContext.refresh   //这个方法就是构建整个Ioc容器过程的完整的代码,了解了里面的每一行代码基本上就了解大部分Spring的原理和功能了。

  1. public void refresh() throws BeansException, IllegalStateException {  
  2.  
  3.     synchronized (this.startupShutdownMonitor) {  
  4.  
  5.         // Prepare this context for refreshing.  
  6.  
  7.         prepareRefresh();  
  8.  
  9.         // Tell the subclass to refresh the internal bean factory.  
  10.  
  11.         ConfigurableListableBeanFactory beanFactory = obtainFreshBeanFactory();  //里面调用loadBeanDefinitions();开始加载、解析 Bean的定义,也就是把用户定义的数据结构转化为Ioc容器中的特定数据结构。
  12.  
  13.         // Prepare the bean factory for use in this context.  
  14.  
  15.         prepareBeanFactory(beanFactory);  //添加一些Spring本身需要的一些工具类
  16.  
  17.         try {  
  18.  
  19.             // Allows post- processing of the bean factory in context subclasses.  
  20.  
  21.             postProcessBeanFactory(beanFactory);  //扩展了Spring的功能: 让你现在可以对已经构建的BeanFactory的配置做修改
  22.  
  23.             // Invoke factory processors registered as beans in& nbsp;the context.  
  24.  
  25.             invokeBeanFactoryPostProcessors(beanFactory);  //扩展了Spring的功能: 让你现在可以对已经构建的BeanFactory的配置做修改
  26.  
  27.             // Register bean processors that intercept bean crea tion.  
  28.  
  29.             registerBeanPostProcessors (beanFactory);  //扩展了Spring的功能: 让你可以对以后再 创建Bean的实例对象时添加一些自定义的操作
  30.  
  31.             // Initialize message source for this context.  
  32.  
  33.             initMessageSource();  
  34.  
  35.             // Initialize event multicaster for this context.  
  36.  
  37.             initApplicationEventMulticaster();  
  38.  
  39.             // Initialize other special beans in specific contex t subclasses.  
  40.  
  41.             onRefresh();  
  42.  
  43.             // Check for listener beans and register them.  
  44.  
  45.             registerListeners();  
  46.  
  47.             // Instantiate all remaining (non-lazy-init) singletons.  
  48.  
  49.             finishBeanFactoryInitialization (beanFactory);  //Bean的实例化
  50.  
  51.             // Last step: publish corresponding event.  
  52.  
  53.             finishRefresh();  
  54.  
  55.         }  
  56.  
  57.         catch (BeansException ex) {  
  58.         略
  59.         }  
  60.  
  61.     }  

一个非常重要的Bean——FactoryBean,

可以说Spring一大半的扩展的功能都与这个Bean有关,这是个特殊的Bean他是个工厂Bean,可以产生Bean的Bean,这里的产生Bean是指 Bean的实例,

如果一个类继承FactoryBean,用户可以自己定义产生实例对象的方法只要实现他的getObject方法。

然后在Spring内部这个Bean的实例对象是FactoryBean,通过调用这个对象的getObject方 法就能获取用户自定义产生的对象,从而为Spring提供了很好的扩展性。Spring获取FactoryBean本身的对象是在前面加上&来完成的。

 

Ioc容器的扩展点

如何让这些Bean对象有一定的扩展性,就是可以加入用户的一些操作。

BeanFactoryPostProcessorBeanPostProcessor。他们分别是在构建BeanFactory和构建Bean对象时调用。

还有就是InitializingBeanDisposableBean 他们分别是在Bean实例创建和销毁时被调用。用户可以实现这些接口中定义的方法,Spring就会在适当的时候调用他们。

还有一个是FactoryBean他是个特殊的Bean,这个Bean可以被用户更多的控制。

 

如何精通Spring就看你有没有掌握好Spring有哪些扩展点,并且如何使用他们,要知道如何使用他们就必须了解他们内在的机理。

把Ioc容器比作一个箱子,

这个箱子里有若干个球的模子,可以用这些模子来造很多种不同的球,

还有一个造这些球模的机器,这个机器可以产生球模。

那么他们的对应关系就是BeanFactory就是 那个造球模的机器

球模就是Bean

而球模造出来的就是Bean的实例

那前面所说的几个扩展点又在什么地方呢?

BeanFactoryPostProcessor对应到当造球模被造出来时,你将有机会可以对其做出设 当的修正,也就是他可以帮你修改球模

InitializingBeanDisposableBean是在球模造球的开始和结束阶段,你可以完成一些预备和扫尾工作

BeanPostProcessor就可以让你对球模造出来的做出 适当的修正

最后还有一个FactoryBean,它可是一个神奇的自定义球模。这个球模不是预先就定型了,而是由你来给他确定它的形状,既然你可以确定这个球模型的形状,当然他造出来的球肯定就是你想要的 球了,这样在这个箱子里尼可以发现所有你想要的球。

 

SpringAOP如何实现

动态代理的实现原理

Jdk动态代理

CGLIB类代理

 

参考资料:

http://developer.51cto.com/art/201006/205212_all.htm

 








以上是关于深入理解java:4.2. 框架编程之Spring框架的设计理念的主要内容,如果未能解决你的问题,请参考以下文章

对Spring的深入理解

Spring框架系列 - 深入浅出Spring核心之面向切面编程(AOP)

深入理解Java注解之:注解的使用

深入理解java:4. 框架编程

深入理解java集合框架之---------Arraylist集合 -----构造函数

深入理解java集合框架之---------Arraylist集合 -----添加方法