(一)Spring的前世今生与宏观认识

Spring的设计初衷

​ Spring是为了解决JavaEE企业级开发复杂性而设计开发的。他的所有理念都可以追溯到一个最根本的目的:简化开发。

基于这个目的,Spring采取了四个关键策略

1、基于POJO的轻量级和最小侵入性编程;

2、通过依赖注入(DI)和面向接口松耦合;

控制反转(IOC)是目的,依赖注入(DI)是手段,IOC指让生成类的方式由传统方式(new)反过来,即程序员不调用new,需要类的时候由框架注入(DI),是同一件事不同层面的解读。

3、基于切面(AOP)和惯性进行声明式编程;

4、通过切面和模板减少样板式编程;

以上四个策略主要是通过:面向Bean(BOP)、依赖注入(DI)、以及面向切面(AOP)三种方式来达成的。

BOP编程起源

​ Spring是面向Bean的编程(Bean Oriented Programming, BOP ),Bean 在 Spring 中才是真正的主角。Bean 在 Spring 中作用就像 Object 对 OOP 的意义一样,他存在的意义也就在于 Bean。

​ Spring 提供了 IOC 容器通过配置文件或者注解的方式来管理对象之间的依赖关系。其中 IOC 的基本概念是:不创建对象,但是描述创建它们的方式。在代码中不直接与对象和服务连接,但在配置文件中描述哪一个组件需要哪一项服务。 重点是描述

容器(在 Spring 框架中是 IOC 容器)负责将这些联系在一起。在典型的 IOC 场景中,容器创建了所有对象,并设置必要的属性将它们连接在一起,决定什么时间调用方法。

依赖注入的基本理念

  • Spring 设计的核心 org.springframework.beans
  • Spring 架构的核心 org.springframework.core

设计核心包的目标是与 JavaBean 组件一起使用,通常不是由用户直接使用,而是由服务器将其用作其他多数功能的底层中介。下一个最高级抽象 BeanFactory 接口,他是工厂设计模式的实现,允许通过名称创建和检索对象。BeanFactory 也可以管理对象之间的关系。

BeanFactory 最底层支持两个对象模型

​ 1、单例模式:提供了具有特定名称的全局共享实例对象,可以在查询时对其进行检索。Singleton (单例模式)是默认的也是最常用的对象模型。

​ 2、原型模式:确保每次检索都会创建单独的实例对象。在每个用户都需要自己的对象时,采用原型模式。

Bean 工程的概念是 Spring 作为 IOC 容器的基础。

IOC 则将处理事情的责任从应用程序代码转移到框架。

AOP (Aspect-OrientedProgramming)编程理念

​ 面向切面编程,即 AOP ,它允许程序员对横切关注点或横切典型的职责分界线的行为(例如日志和事务管理)进行模块化

​ AOP 的核心构造是方面(切面),它将那些影响多个类的行为封装到可重用的模块中。

​ AOP 的功能完全集成到了 Spring 事务管理、日志和其他各种特性的上下文中。

​ AOP 的本质是在一系列纵向的控制流程中,把那些相同的子流程提取成一个横向的面,面向这些横向的面进行操作。

Spring 5 系统架构

​ Spring 总共大约有 20 个模块,由 1300 多个不同的文件构成。而这些组件被分别整合在核心容器(Core Container)、AOP(Aspect Oriented Programming)和设备支持(Instrmentation)、数据访问及集成(Data Access/Integeration)、Web、报文发送(Messaging)、Test,6 个模块集合中。

系统架构图

Spring5 系统架构

核心容器

​ 由 spring-beans、spring-core、spring-context 和 spring-expression(Spring Expression Language, SpEL) 4 个模块组成。

​ spring-core 和 spring-beans 模块是 Spring 框架的核心模块,包含了控制反转(Inversion of Control, IOC)和依赖注入(Dependency Injection, DI)。

​ BeanFactory 接口是 Spring 框架中的核心接口,它是工厂模式的具体实现。BeanFactory 使用控制反转对应用程序的配置和依赖性规范与实际的应用程序代码进行了分离。但 BeanFactory 容器实例化后并不会自动实例化 Bean,只有当 Bean 被使用时 BeanFactory 容器才会对该 Bean 进行实例化与依赖关系的装配

​ spring-context 模块构架于核心模块之上,他扩展了 BeanFactory,添加了 Bean 生命周期控制、框架事件体系以及资源加载透明化等功能。 此外该模块还提供了许多企业级支持,如邮件访问、远程访问、任务调度等ApplicationContext 是该模块的核心接口,他的超类是 BeanFactory。 **与BeanFactory 不同,该容器实例化后会自动对所有的单实例 Bean 进行实例化与依赖关系的装配,使之处于待用状态。 **

​ spring-context-support 模块是对 Spring IOC 容器的扩展支持,以及 IOC 子容器。

​ spring-context-indexer 模块是 Spring 的类管理组件和 Classpath 扫描。

​ spring-expression 模块是统一表达式语言(EL)的扩展模块,可以查询、管理运行中的对象,同时也方便的可以调用对象方法、操作数组、集合等。

AOP 和设备支持

​ 由 spring-aop、spring-aspects 和 spring-instrument 3个模块组成。spring-aop 是 Spring 的另-个核心模块,是 AOP 主要的实现模块。作为继 OOP 后,对程序员影响最大的编程思想之一,AOP 极大地开拓了人们对于编程的思路。

在 Spring 中,他是以 JVM 的动态代理技术为基础,然后设计出了一系列的AOP横切实现,比如前置通知、返回通知、异常通知等,同时,Pointcut 接口来匹配切入点,可以使用现有的切入点来设计横切面,也可以扩展相关方法根据需求进行切入。

​ spring-aspects 模块集成自 AspectJ 框架,主要是为Spring AOP提供多种AOP实现方法。

​ spring -instrument 模块是基于 Java SE 中的 “java.lang.instrument” 包进行设计的,应该算是AOP的一个支援模块,主要作用是在 JVM 启用时,生成- -个代理类, 程序员通过代理类在运行时修改类的字节,从而改变一个类的功能,实现 AOP 的功能。

数据访问与集成

​ 由 spring-jdbc、 spring-tx、 spring-orm、 spring-jms 和 spring-oxm 5个模块组成。

​ spring-jdbc 模块是 Spring 提供的 JDBC 抽象框架的主要实现模块,用于简化 Spring JDBC操作。主要是提供JDBC模板方式、关系数据库对象化方式、SimpleJdbc 方式、事务管理来简化 JDBC 编程,主要实现类是JdbcTemplate、SimpleJdbcTemplate 以及 NamedParameterJdbcTemplate。

​ spring-tx 模块是 Spring JDBC 事务控制实现模块。使用 Spring 框架,它对事务做了很好的封装,通过它的 AOP 配置,可以灵活的配置在任何一层;但是在很多的需求和应用,直接使用 JDBC 事务控制还是有其优势的。其实,事务是以业务逻辑为基础的; 一个完整的业务应该对应业务层里的一个方法;

​ **如果业务操作失败,则整个事务回滚;所以,事务控制是绝对应该放在业务层的;**但是,持久层的设计则应该遵循一个很重要的原则:保证操作的原子性,即持久层里的每个方法都应该是不可以分割的。所以,在使用Spring JDBC 事务控制时,应该注意其特殊性。


Web 组件

​ 由 spring-web、spring-webmvc、 spring-websocket 和spring-webflux 4个模块组成。

​ spring-web 模块为Spring 提供了最基础 Web 支持,主要建立于核心容器之上,通过 Servlet 或者 Listeners 来初始化 IOC 容器,也包含一些与 Web 相关的支持。

​ spring-webmvc 模块众所周知是一个的 Web-Servlet 模块,实现了Spring MVC(model-view-Controller)的Web应用。

​ spring-websocket 模块主要是与 Web 前端的全双工通讯的协议。

​ spring-webflux 是一个新的非堵塞函数式 Reactive Web 框架,可以用来建立异步的,非阻塞的,事件驱动的服务,并且扩展性非常好。

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值