【0】README
0.1)本文部分文字描述转自:“Spring In Action(中/英文版)”,旨在reviewSpring(1)Spring之旅 的相关知识;
【1】简化java 开发
1)为了降低java开发的复杂性,Spring采取了以下4种关键策略(strategy):
s1)基于POJO的轻量级和最小侵入性编程;(POJO == plain ordinary java object,简单java对象 == 普通javabean)
s2)通过依赖注入和面向接口实现松耦合;
s3)基于切面和惯例进行声明式编程;
s4)通过切面和模板减少样板式代码;
【1.2】依赖注入(Dependency Injection==DI)
1)耦合具有两面性:
1.1)一方面:紧密耦合的代码难以测试,难以复用,难以理解,并且典型地表现出打地鼠式的bug特性(修复一个bug,将会出现一个或更多新的bug);(干货——新贵词汇——打地鼠式的bug特性)
1.2)另一方面:一定程度的耦合又是必须的——完全没有耦合的代码什么都做不了;(总而言之,耦合是必须的,但应该被小心谨慎地管理);
2)通过DI,对象的依赖关系将由系统中负责协调各对象的第三方组件在创建对象的时候进行设定;
3)这就是DI所带来的最大收益——松耦合。如果一个对象只通过接口(而不是具体实现或初始化过程)来表明依赖关系,那么这种依赖就能够在对象本身毫不知情的case下,用不同的具体实现进行替换;(干货——DI所带来的最大收益——松耦合)
4)创建应用组件之间协作的行为通常称为装配:Spring有多种装配bean 的方式,采用XML 是很常见的一种装配方式,也可以使用 java 来描述配置;(干货——装配的定义)
5)Spring通过应用上下文装置bean的定义并把他们组装起来。Spring应用上下文全权负责对象的创建和组装。Spring自带了多种应用上下文的实现,它们之间的主要区别仅仅在于 如何加载配置;
【1.3】应用切面
1)DI 能够让相互协作的软件组件保持松散耦合,而面向切面编程(AOP)允许你把遍布应用各处的功能分离出来形成可重用的组件;(干货——面向切面编程的定义)
2)面向切面编程往往被定义:为促使软件系统实现关注点的分离一项技术。系统由许多不同的组件组成,每一个组件各负责一块特定功能。除了实现自身核心的功能之外,这些组件还经常承担额外的职责。诸如日志,事务管理和安全这样的系统服务经常融入到自身具有核心业务逻辑的组件中去,这些系统服务通常被称为横切关注点,因为他们会跨越系统的多个组件;(干货——横切关注点的定义)
3)AOP能够使这些服务模块化,并以声明的方式将它们应用到他们需要影响的组件中去。所造成的结果就是这些组件会具有更高的内聚性并且会更加关注自身的业务,完全不需要了解涉及系统服务所带来复杂性。总之,AOP 能够确保POJO的简单性;
4)看个荔枝:(本小姐末有辅助图说明)
4.0)相关源码
public class KnightMain {
public static void main(String[] args) throws Exception {
String dir = System.getProperty("user.dir") + File.separator + "META-INF" + File.separator;
FileSystemXmlApplicationContext context = new FileSystemXmlApplicationContext(dir+"knight.xml");
Knight knight = context.getBean(Knight.class);
knight.embarkOnQuest();
context.close();
}
}
对以上代码的分析(Analysis):
A1)使用FileSystemXmlApplicationContext 和 使用 ClassPathXmlApplicaitonContext的区别在于:FileSystemXmlApplicationContext 在指定的文件系统路径下查找 knight.xml 文件,而 ClassPathXmlApplicationContext 是所有的类路径(包含 JAR文件)下查找knight.xml 文件;
A2)如果你想从java 配置中加载应用上下文,那么可以使用 AnnotationConfigApplicationContext:
ApplicationContext context = new AnnotationConfigApplicationContext(com.spring.chapter1.KnightConfig.class);
4.1)console info:
五月 26, 2016 4:37:43 下午 org.springframework.context.support.AbstractApplicationContext prepareRefresh
信息: Refreshing org.springframework.context.support.FileSystemXmlApplicationContext@179d3b25: startup date [Thu May 26 16:37:42 CST 2016]; root of context hierarchy
五月 26, 2016 4:37:43 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from file [E:\bench-cluster\cloud-data-preprocess\SpringInAction4\META-INF\knight.xml]
before: Fa la la, the knight is so brave! // higglight line.
Embarking on quest to slay the dragon! // highlight line.
after: Tee hee hee, the brave knight did embark on a quest! // highlight lien.
五月 26, 2016 4:37:43 下午 org.springframework.context.support.AbstractApplicationContext doClose
信息: Closing org.springframework.context.support.FileSystemXmlApplicationContext@179d3b25: startup date [Thu May 26 16:37:42 CST 2016]; root of context hierarchy
4.2)本文还是习惯上给出以上测试用例的调用过程
【2】容纳你的bean
1)intro to Spring容器:在基于spring的应用中,你的应用对象生存于Spring容器中;(干货——Spring容器的作用——Spring容器负责创建应用程序中的bean并通过DI 来协调这些对象之间的关系)
2)spring容器并不是只有一个。Spring自带了多个容器实现,可以归为两种不同的类型:
type1)bean工厂(org.springframework.beans.factory.eanFactory.context.ApplicationContext接口定义)是最简单的 容器,提供基本的DI支持;
type2)应用上下文(由 org.springframework.context.ApplicationContext接口定义)基于BeanFactory构建,并提供应用框架级别的访问;
3)推荐使用应用上下文,因为bean工厂对大多数应用来说太low了;
【2.1】使用应用上下文
1)Spring自带了多种类型的应用上下文,下面罗列了几个最可能遇到的;
case1)AnnotationConfigApplicationContext:从一个或多个基于java 的配置类中加载Spring应用上下文;
case2)AnnotationConifgWebApplicationContext:从一个或多个基于java 的配置类中加载Spring Web应用上下文;
case3)ClassPathXmlApplicationContext:从类路径下的一个或多个XML配置文件中加载上下文定义,把应用上下文的定义文件作为类资源;
case4)FileSystemXmlApplicationContext:从文件系统下的一个或多个XML配置文件中加载上下文定义;
case5)XmlWebApplicationContext:从web 应用下的一个或多个XML 配置文件中加载上下文定义;
Attention)使用FileSystemXmlApplicationContext 和 使用 ClassPathXmlApplicaitonContext的区别在于:(这里再次提供了它们的区别)FileSystemXmlApplicationContext 在指定的文件系统路径下查找 knight.xml 文件,而 ClassPathXmlApplicationContext 是所有的类路径(包含 JAR文件)下查找knight.xml 文件;
【3】Spring模块
1)intro:在Spring4.0中, Spring框架的发布版本包括了20个不同的模块,每个模块会有3个JAR文件(二进制类库,源码jar,以及javadoc的jar);