前言

现在Spring几乎成为了Java在企业级复杂应用开发的代名词,得益于Spring简单的设计哲学和其完善的生态圈,确实为廉颇老矣,尚能饭否的 Java 带来了“春天”,有很多同学刚接触Java就直接从Spring框架开始学习,导致产生了很多疑惑,甚至有很多同学只知道用Spring,并不了解其中的原理,例如:

  1. Spring框架为我们做了什么,没有Spring框架前我们的程序是什么样的?
  2. 为什么要把对象放在Spring容器里面,为什么我不能直接new对象?
  3. 为什么要把Sevlet交给Spring MVC管理,我自己写Sevlet处理HTTP请求不行吗?
  4. Spring为什么要封装这么多的 Template(JDBCTemplate,RestTemplate等……)它想要干什么?

Spring 生态遍地开发(SpringBoot,SpringCloud 等等),本篇文章不会深入探讨Spring 每个框架的实现细节,只会大概讲Spring Framework背后的设计理念和它为我们所做的事情,让大家知其然并知其所以然,可以在用 Spring 的时候能知悉底层和内部细节发生的事情,如果是对于 Spring Frameword 和其生态框架的细节有兴趣的同学可以在详尽的阅读官方的文档,https://spring.io/projects(这应该是我见过写的最好的技术文档之一)

Spring 为我们做了哪些事情?

Spring 全家桶框架众多,但主要的设计原则简单来说,离不开这几点:

  • 通过代码解耦,提高代码灵活性(依赖注入 DI)
  • 简化开发,用最少的代码,做最多的事情(AOP,Template)
  • 提供公共抽象,屏蔽底层,开箱即用,替换方便(Spring Cache,框架,中间件集成)
  • MVC模型的快速实现(视图解析,数据转换)

下面拆开来说说这几点,为我们带来什么好处,最后探讨下,如果没有 Spring 用原生的 J2EE 我们的程序会变成什么样

先说说 Spring Framework 的核心功能,DI 依赖注入,AOP 面向切面编程

依赖注入也叫 IOC 控制反转,依赖注入是编程大师 Martin Fowler 提出来的,我个人比较喜欢依赖注入这个名词,感觉比控制反转更具有表达性,也更容易理解

那么依赖注入为我们做了什么 ?

  • 灵活:依提供的面向接口的编程方法,为类和类之间建立更灵活的关系
  • 解耦:移除了直接在程序中 new 实例的高耦合做法
  • 方便:要替换类的实现,只需要在 Spring 容器中更换声明,无需改动代码

那么 AOP 面向切面又为我们做了什么?

  • 消除重复的模板代码(性能监控,异常封装,参数跟踪等……)
  • 更代码结构更加整洁,通用的逻辑基本都可以用 AOP 来处理
  • Spring 的声明式事务就是 Spring AOP 的优秀实现案例

还为我们做了什么其他的事情?

  • Spring JdbcTemplate 消除了JDBC API令人诟病的模板代码
  • Spring Cache 提供缓存功能,并且无需关心底层缓存组件细节(Ehcache,Guava,JSR-107 Cache等……)
  • Spring DAO 提供连接池功能,并且无需关心底层连接池组件细节(C3P0,DBCP等……)
  • 提供 定时任务功能 集成(Quartz,JDK Timer,Executor)
  • 整合ORM框架,测试框架集成
  • 快速实现MVC模型,并且集成Sring,数据处理,视图解析等都由Spring处理

以上等等功能,都是 Spring 框架为我们做处理的事情

当然 Spring 生态里还有非常多的框架来简化我们的日常开发,提高开发效率,常用的例如:

  • Spring Boot (无需配置,快速开发,启动,集成生产级的监控指标)
  • Spring Cloud(快速实现微服务的框架,提供系列微服务的组件框架)
  • Spring Shrio(基于角色资源的安全框架,利用AOP实现鉴权等安全访问的功能)
  • Spring Data(提供数据访问实现,包括非关系数据库,关系数据库,云数据服务等)

假如没有 Spring ?

让我们想象一下,假如没有 Spring,我们在做企业级应用开发会大概会发生什么事情?

  • 类和类之间通过 new 建立关系,充满耦合,小处改动都要修改大量代码
  • 充满和业务无关的模板代码,10行代码可能只有1行是业务逻辑
  • 大量的事务,异常,JDBC的模板处理代码,不仅代码极度脆弱,容易出错,而且可读性极差,基本不可维护
  • 你要为每个请求写一个 Servlet 处理,并且自己处理 request/response,Servlet 也充斥着大量重复的模板代码
  • 你项目的代码量可能会比现在多很多

以上,你是如何看待 Spring 带来的复杂性和提供的便利性?现在 Spring 体系也越来越庞大,貌似与它刚开始对抗 EJB 的时候所提出的轻量级,简单的设计原则开始背道而驰,关于这点你又是怎么评价呢?个人知识有限,不喜勿喷,欢迎发表评论和分享你的观点和看法。

为什么你要用 Spring?的更多相关文章

  1. 阅读spring源码

    读Spring源码之前,你要先清楚,为什么你要用Spring... Spring最基本的功能是做为管理bean的容器,所以我以为应该先从org.springframework.context包了解咯, ...

  2. 五分钟学Java:一篇文章搞懂spring和springMVC

    原创声明 本文作者:黄小斜 转载请务必在文章开头注明出处和作者. 本文思维导图 什么是Spring,为什么你要学习spring? 你第一次接触spring框架是在什么时候?相信很多人和我一样,第一次了 ...

  3. 五分钟学Java:一篇文章带你搞懂spring全家桶套餐

    原创声明 本文首发于微信公众号[程序员黄小斜] 本文作者:黄小斜 转载请务必在文章开头注明出处和作者. 本文思维导图 什么是Spring,为什么你要学习spring? 你第一次接触spring框架是在 ...

  4. 基于spring注解AOP的异常处理

    一.前言 项目刚刚开发的时候,并没有做好充足的准备.开发到一定程度的时候才会想到还有一些问题没有解决.就比如今天我要说的一个问题:异常的处理.写程序的时候一般都会通过try...catch...fin ...

  5. 玩转spring boot——快速开始

    开发环境: IED环境:Eclipse JDK版本:1.8 maven版本:3.3.9 一.创建一个spring boot的mcv web应用程序 打开Eclipse,新建Maven项目 选择quic ...

  6. Spring基于AOP的事务管理

                                  Spring基于AOP的事务管理 事务 事务是一系列动作,这一系列动作综合在一起组成一个完整的工作单元,如果有任何一个动作执行失败,那么事务 ...

  7. [Spring]IoC容器之进击的注解

    先啰嗦两句: 第一次在博客园使用markdown编辑,感觉渲染样式差强人意,还是github的样式比较顺眼. 概述 Spring2.5 引入了注解. 于是,一个问题产生了:使用注解方式注入 JavaB ...

  8. 学习AOP之透过Spring的Ioc理解Advisor

    花了几天时间来学习Spring,突然明白一个问题,就是看书不能让人理解Spring,一方面要结合使用场景,另一方面要阅读源代码,这种方式理解起来事半功倍.那看书有什么用呢?主要还是扩展视野,毕竟书是别 ...

  9. 学习AOP之深入一点Spring Aop

    上一篇<学习AOP之认识一下SpringAOP>中大体的了解了代理.动态代理及SpringAop的知识.因为写的篇幅长了点所以还是再写一篇吧.接下来开始深入一点Spring aop的一些实 ...

随机推荐

  1. Python将pyc转为py

    安装pip install uncompyle2, 使用uncompyle2 xxx.pyc > xxx.py

  2. 跟我学SpringCloud | 第十四篇:Spring Cloud Gateway高级应用

    SpringCloud系列教程 | 第十四篇:Spring Cloud Gateway高级应用 Springboot: 2.1.6.RELEASE SpringCloud: Greenwich.SR1 ...

  3. Linux命令学习-tar命令

    Linux中,tar命令的全称是tape archive,主要作用是压缩和解压文件. 参数说明: -c 创建新的压缩档案 -x 解压档案 -t 列出压缩档案的内容 -z 使用gzip来解压和压缩,文件 ...

  4. Notepad++提升工作效率小技巧

    前言 简单的提升工具效率需求可以借助Notepad编辑器实现.以前也用Python/Shell开发过本文中提到的需求,现在发现其实没有必要.本文介绍一些工作中常见的可以通过"Notepad+ ...

  5. C++学习书籍推荐《Exceptional C++》下载

    百度云及其他网盘下载地址:点我 编辑推荐 <Exceptional C++:47个C++工程难题.编程问题和解决方案(中文版)>中的每个问题都给出了难度系数,在这些问题中阐释一些微妙的编程 ...

  6. Java学习笔记之---单例模型

    Java学习笔记之---单例模型 单例模型分为:饿汉式,懒汉式 (一)要点 1.某个类只能有一个实例 2.必须自行创建实例 3.必须自行向整个系统提供这个实例 (二)实现 1.只提供私有的构造方法 2 ...

  7. IIS配置应用时,请求Header或Cookie过长

    可以在注册表中配置IIS MaxFieldLength MaxRequestBytes 注意配置后需重启http服务于iis服务 net stop http net start http iisres ...

  8. php接口数据安全解决方案(二)

    前言 实例演示token签名并创建token 解析token并校验token合法性 类库封装管理jwt实例 前言 JWT是什么 JWT是json web token缩写.它将用户信息加密到token里 ...

  9. Communicating with the UI Thread_翻译

    In the previous lesson you learned how to start a task on a thread managed by ThreadPoolExecutor. Th ...

  10. JQuery学习笔记(3)——节点操作 节点查找

    插入节点 内部插入 所谓的内部插入,就是指在节点里面的插入,而外部插入,则是在节点外面插入. append() prepend() appendTo() prependTo() append和prep ...