前言:

这个问题也一直困惑我很久,毕竟其他语言没有IOC也活的很好。

但是Spring在当时能够一统江湖,跟IOC真的有很大的关系。

在没有IOC的时代,New代表一切,女朋友都是可以New出来的。

那么,倒底为什么要去除掉New,想出来IOC这种绝世设计呢?

按照上帝视角的原则,我们还是先看一下,New会出现什么问题,再去推导一下,IOC有没有解决掉这个问题。

正文:

暗灭大人曾经说过,软件开发分成以下几个阶段:

  • 面向功能编程
  • 面向复用编程
  • 面向性能编程
  • 面向未来编程
  • 面向造物编程

大部人都停留在面向功能编程的阶段,而New,就是用来完成面向功能编程的常用手段。

同样的,在面向功能编程阶段还有以下特征:

  1. 耦合度高
  2. 代码行数长,很少做抽象
  3. 硬编码多,没有扩展性
  4. 数据和代码混在一起,无法复用
  5. Hack代码到处都是
  6. 不考虑未来需求的变更

New的问题就在于是,如果说有多个地方调用了一个方法,而我又要更改这个方法,怎么办?

最简单也是最容易理解的,就是短信服务。

在短信服务这个场景中,短信通道经常是不可控的,会被替换的,又是整个系统,特别是在用户登录的过程中非常重要的环节。

运营商是把通道卖给各种公司,各种公司用通道构造成一个个的短信服务,这些短信服务公司,接口不一致,实现方案不一样,没什么标准化。

而且短信又是最容易被用做短信炸弹的,用户投拆之后,通道就会被封,老板一着急,肯定是希望说我要换短信通道 。

这就是需求的来源,很简单,最终形成的结论就是我要换短信通道。

怎么个换法呢?系统里使用短信通道的地方会有很多,注册需要,修改密码需要,后台管理群发短信的时候可能也需要,有一些特殊提醒需要发短信,还是需要。

多个环节,要改动实现类,怎么改?比如说我要从容联的通道改到创蓝的通道。

重新改代码都是需要调试,接口不一致,参数不一致,往往会导致出一些问题。

那么要改进怎么解决呢?

第一件事就是要学习秦始皇,统一哈。

怎么统一呢?用Java的接口和实现类。我把所有短信提供的服务,声明出来,这叫作接口,就是用来告诉调用方,你需要传给我什么参数,我需要返回给你什么参数。

这是接口。

那么对应的,就是有实现类。

接口和实现类,其实也很常见。比如说,http协议,CSS等都是一波人定协议,另外一波人遵循这个规范去做实现。

接口和实现有这个意思。

所以第一步很关键点就在于是,我们先把接口和实现抽离,这样的好处是什么呢?

无论你的短信通道是什么样的方式,是Http的还是Socket的,还是其他的方式,对外而言,统一暴露的就是一致的接口。手机号和内容。

好了第一步有了。这样看起来就好多了。这个时候仍然是New。

只不过,换类的时候,因为接口是一致的,所以我只需要改

 SMSService smsService= new SMSServiceRongLianImpl();
int code = smsService.sendMsg(phone,msg);

变成

  SMSService smsService= new SMSServiceChuangLanImpl();
int code = smsService.sendMsg(phone,msg);

不影响其他的实现。是不是看起来比之前要好很多了?

毕竟大家这个时候统一使用的是smsService,而根本不关心这个smsService倒底是哪一个实现类。

这个时候,一个大胆的想法就出来了。

既然我不关心smsService是由哪一个实现类构成的。

我为什么要在一个方法被调用的时候去实例化它呢?为什么我不在一开始,我的类构造的时候就创建他呢?

先是有一个私有的属性。

private SMSService smsService;

然后在构造函数中

super();
this.smsService= new SMSServiceChuangLanImpl();

这样的原来的代码只有一句

 int code = smsService.sendMsg(phone,msg);

这样是不是让我们的业务代码更简洁了?而且很有包办婚姻的快感,你根本不用自己谈恋爱,父母给你定好你就完成你的洞房任务就好了。

想换老婆?对不起,先要让你的父母同意,只要你的父母同意了,随便你换。

总之,你就是要和你的媳妇结婚洞房。

到了这里,其实第三步已经很清楚了。

我既然可以用构造函数实例化,可不可以用Set方法,把构造函数省去,用外部配置来完成smsService的实例化呢?

这样的好处是什么呢?

在我的调用者代码中,完全不需要知道smsService倒底是认谁,父母之命,媒妁之言。

通过配置文件或者是Annonation的方式,将实现类注入到调用者那里去,这其实才是IOC的核心。

所以IOC的好处,就是分成三个阶段来看,离不开接口和实现的设计模式。

  1. 统一第三方服务的参数和返回值,抽像出来接口。
  2. 将原来方法中对接口实例化的代码剥离出来到构造函数中。
  3. 通过配置文件,可以做到改变实现类,而不改变任何一个调用者的代码(IOC)。

写在最后:欢迎留言讨论,加关注,持续更新!!!

Java架构师告诉你Spring IoC有什么好处呢的更多相关文章

  1. Java架构师之路 Spring学习笔记(一) Spring介绍

    前言 这是一篇原创的Spring学习笔记.主要记录我学习Spring4.0的过程.本人有四年的Java Web开发经验,最近在面试中遇到面试官总会问一些简单但我不会的Java问题,让我觉得有必要重新审 ...

  2. 阿里十年架构师告诉你Spring Boot与Spring Cloud是什么关系

    SpringBoot先于Spring Cloud问世.SpringBoot相当于脚手架,借助他可以快速搭建房子,它本身不具备任何功能属性,值是普通房间,没有其他任何功能. 什么是Spring Boot ...

  3. 15套java架构师、集群、高可用、高可扩展、高性能、高并发、性能优化、Spring boot、Redis、ActiveMQ、Nginx、Mycat、Netty、Jvm大型分布式项目实战视频教程

    * { font-family: "Microsoft YaHei" !important } h1 { color: #FF0 } 15套java架构师.集群.高可用.高可扩展. ...

  4. java架构师负载均衡、高并发、nginx优化、tomcat集群、异步性能优化、Dubbo分布式、Redis持久化、ActiveMQ中间件、Netty互联网、spring大型分布式项目实战视频教程百度网盘

    15套Java架构师详情 * { font-family: "Microsoft YaHei" !important } h1 { background-color: #006; ...

  5. Java 架构师+高并发+性能优化+Spring boot大型分布式项目实战

    视频课程内容包含: 高级 Java 架构师包含:Spring boot.Spring cloud.Dubbo.Redis.ActiveMQ.Nginx.Mycat.Spring.MongoDB.Zer ...

  6. 15套java架构师大型分布式综合项目实战、千万高并发-视频教程

    * { font-family: "Microsoft YaHei" !important } h1 { color: #FF0 } 15套java架构师.集群.高可用.高可扩 展 ...

  7. 15套java架构师、集群、高可用、高可扩 展、高性能、高并发、性能优化Redis、ActiveMQ、Nginx、Mycat、Netty、Jvm大型分布式项目实战视频教程

    * { font-family: "Microsoft YaHei" !important } h1 { color: #FF0 } 15套java架构师.集群.高可用.高可扩 展 ...

  8. Java架构师系统培训高并发分布式电商实战activemq,netty,nginx,redis dubbo shiro jvm虚拟机视频教程下载

    15套java架构师.集群.高可用.高可扩 展.高性能.高并发.性能优化.Spring boot.Redis.ActiveMQ.Nginx.Mycat.Netty.Jvm大型分布 式项目实战视频教程 ...

  9. JAVA高级架构师基础功:Spring中AOP的两种代理方式:动态代理和CGLIB详解

    在spring框架中使用了两种代理方式: 1.JDK自带的动态代理. 2.Spring框架自己提供的CGLIB的方式. 这两种也是Spring框架核心AOP的基础. 在详细讲解上述提到的动态代理和CG ...

随机推荐

  1. (十八)JDBC优化使用(一)

    一.将增删改方法合并,优化代码 第十七篇的UserPOImpl.java类代码可以进行优化,因为增删改方法用的都是同一种执行方法executeUpdate(),对十七篇的例子进行优化如下: 2.1 搭 ...

  2. vmware安装centos7.5、配置网卡、环境配置

    1.vmware安装centos7.5虚拟机    参考连接: https://blog.csdn.net/guo_ridgepole/article/details/78973763 可能遇到的问题 ...

  3. mysql 数据库批量刷新表字段数据

    UPDATE a,bSET b.studentno = a.studentnumber WHERE b.studentno IS NULL AND a.p_id = b.p_id

  4. python map函数(23)

    截至到目前为止,其实我们已经接触了不少的python内置函数,而map函数也是其中之一,map函数是根据指定函数对指定序列做映射,在开发中使用map函数也是有效提高程序运行效率的办法之一. 一.语法定 ...

  5. CNN-4: GoogLeNet 卷积神经网络模型

    1.GoogLeNet 模型简介 GoogLeNet 是2014年Christian Szegedy提出的一种全新的深度学习结构,该模型获得了ImageNet挑战赛的冠军. 2.GoogLeNet 模 ...

  6. airflow安装rest api插件发现airflow webserver服务不能启动的解决办法

    安装插件airflow-rest-api 1)获取 wget https://github.com/teamclairvoyant/airflow-rest-api-plugin/archive/ma ...

  7. MySQL和Oracle的区别与不同

    一.mysql与Oracle的相同点: 1.都是关系型数据库管理系统(MySQL开放源码) 2.都是目前很流行的数据库(Oracle以分布式为核心): 二.MySQL.Oracle各自特点: 1.Or ...

  8. (八)JSP 技术知识点总结(来自那些年的笔记)

    目录 什么是 jsp Jsp 调用和运行原理(简略版) Jsp语法 Jsp指令简介 Page指令 Include指令 taglib指令 Jsp乱码问题 jsp运行原理(详细版) JSP中的九大隐式对象 ...

  9. HTML 是什么?

    HTML 指的是超文本标记语言(英语:HyperText Markup Language),是用来描述网页的一种语言. HTML 不是一种编程语言,而是一种标记语言,它有一套标记标签 . HTML 使 ...

  10. LIUNX随堂学习-3 权限

    1.权限分为三类:读r,写w,执行x 2.读r:可以ls改目录下的子文件名,子目录名 写w:可以在该目录下创建.删除.重命名 执行x:可以cd到该目录下 3. ll  (ls -l) 下详细信息的意义 ...