Spring核心结构
基本概念
Spring是⼀个分层⾮常清晰并且依赖关系、职责定位⾮常明确的轻量级框架,主要包括⼏个⼤模块:数据处理模块、Web模块、AOP(Aspect Oriented Programming)/Aspects模块、Core Container模块和 Test 模块,Spring依靠这些基本模块,实现了⼀个融合了现有解决⽅案的零侵⼊的轻量级框架。
Spring框架结构图如下所示:
五大核心模块
Spring核⼼容器(Core Container) :
- 容器是Spring框架最核⼼的部分,它管理着Spring应⽤中bean的创建、配置和管理。
- 在该模块中,包括了Spring bean⼯⼚,它为Spring提供了DI(依赖注入)的功能。
- 基于bean⼯⼚,我们还会发现有多种Spring应⽤上下⽂的实现。
- 所有的Spring模块都构建于核⼼容器之上。
⾯向切⾯编程(AOP)/Aspects:
- Spring对⾯向切⾯编程提供了丰富的⽀持。
- 这个模块是Spring应⽤系统中开发切⾯的基础,与DI⼀样,AOP可以帮助应⽤对象解耦。
数据访问与集成(Data Access/Integration):
- Spring的JDBC和DAO模块封装了⼤量样板代码,这样可以使得数据库代码变得简洁,也可以更专注于我们的业务,还可以避免数据库资源释放失败⽽引起的问题。
- 另外,Spring AOP为数据访问提供了事务管理服务,同时Spring还对ORM进⾏了集成,如Hibernate、MyBatis等。该模块由JDBC、Transactions、ORM、OXM 和 JMS 等模块组成。
Web模块:
- 该模块提供了SpringMVC框架给Web应⽤,还提供了多种构建和其它应⽤交互的远程调⽤⽅案。
- SpringMVC框架在Web层提升了应⽤的松耦合⽔平。
Test模块:
- 为了使得开发者能够很⽅便的进⾏测试,Spring提供了测试模块以致⼒于Spring应⽤的测试。
- 通过该模块,Spring为使⽤Servlet、JNDI等编写单元测试提供了⼀系列的mock对象实现。
Spring核心思想
IoC(Inversion of Control (控制反转/反转控制))
基本概念
IoC是一种技术思想,而不是一种技术实现。
IoC描述的是Java开发领域对象的创建和管理问题。
对比
传统开发⽅式:⽐如类A依赖于类B,往往会在类A中new⼀个B的对象。
IoC思想下开发⽅式:我们不⽤⾃⼰去new对象了,⽽是由IoC容器(Spring框架)去帮助我们实例化对象并且管理它,我们需要使⽤哪个对象,去问IoC容器要即可。
我们失去了创建和管理对象的权利,同时得到了⼀个福利(不⽤考虑对象的创建和管理等⼀系列事情)。
如下图所示:
为什么叫做控制反转
控制:指的是对象创建(实例化和管理)的权利。
反转:控制权交给外部环境了(spring框架、IoC容器)。
IoC解决了对象之间的耦合问题
IoC和DI(Dependancy Injection(依赖注⼊))的区别
IoC和DI描述的是同⼀件事情(对象实例化与依赖关系维护),只不过⻆度不⼀样罢了。
Ioc是站在对象的角度,对象实例化及其管理的权利交给了容器(反转)。
DI是站在容器的角度,容器会把对象依赖的其它对象注入,比如A对象实例化过程中因为声明了一个B类型的属性,那么就需要容器把B对象注入给A。
如下图所示:
AOP(Aspect oriented Programming (⾯向切⾯编程/⾯向⽅⾯编程))
AOP是OOP(OOP三⼤特征:封装、继承和多态,OOP是⼀种垂直继承体系)的延续。
OOP思想体系
OOP编程思想可以解决⼤多数的代码重复问题,但是有⼀些情况是处理不了的,⽐如下⾯的在顶级⽗类中的多个⽅法中相同位置出现了重复代码,OOP就解决不了,如下图所示:
横切逻辑代码
在多个纵向(顺序)流程中出现的相同子流程代码,我们称之为横切逻辑代码。
横切逻辑代码的使用场景很有限:一般是事务控制、权限校验和日志等。
以上文中的Animal类中的性能监控代码为例:
存在的问题:
- 横切代码重复问题。
- 横切逻辑代码和业务代码混杂在⼀起,代码臃肿,维护不⽅便。
AOP的提出
AOP独辟蹊径提出横向抽取机制,将横切逻辑代码和业务逻辑代码进行拆分:
AOP解决了什么问题:
在不改变原有业务逻辑的情况下,增强横切逻辑代码,从根本上解耦合,避免横切逻辑代码重复。
为什么叫做⾯向切⾯编程:
- 「切」:指的是横切逻辑,原有业务逻辑代码我们不能动,只能操作横切逻辑代码,所以⾯向横切逻辑。
- 「⾯」:横切逻辑代码往往要影响的是很多个⽅法,每⼀个⽅法都如同⼀个点,多个点构成⾯,有⼀个⾯的概念在⾥⾯。