Spring核心结构及核心思想

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解决了什么问题:

在不改变原有业务逻辑的情况下,增强横切逻辑代码,从根本上解耦合,避免横切逻辑代码重复。

为什么叫做⾯向切⾯编程:

  • 「切」:指的是横切逻辑,原有业务逻辑代码我们不能动,只能操作横切逻辑代码,所以⾯向横切逻辑。
  • 「⾯」:横切逻辑代码往往要影响的是很多个⽅法,每⼀个⽅法都如同⼀个点,多个点构成⾯,有⼀个⾯的概念在⾥⾯。
posted @ 2021-01-25 22:37  blayn  阅读(696)  评论(0编辑  收藏  举报