耦合性是软件工程中的一个重要概念。对象之间的耦合性就是对象之间的依赖性。对象之间的耦合越高,维护成本越高。因此对象的设计应使类和构件之间的耦合最小。 spring Ioc思想 控制翻转也就是spring所推出的依赖注入

传统的方法假设我们前端用的struts,那么action中我们对业务逻辑的编写一般是这样的

这里是一段伪代码:


publicclass CustomerDao {  publicboolean getCustomerByAccount() {/* 代码 */ }      } 
publicclass LoginAction {  publicvoid execute() {              CustomerDao cdao =new CustomerDao();  boolean b = cdao.getCustomerByAccount();  // 判断          }      }

在LoginAction中,execute内直接实例化了CustomerDao对象,此时,相当于让LoginAction的使用依赖了 CustomerDao,换句话说,如果没有CustomerDao类,LoginAction将无法被编译、测试。另外,如果CustomerDao类 换成另一版本,比如原先的CustomerDao,是访问SQLServer数据库,后面我们又另外编写了CustomerDao2类,访问Oracle 数据库,那么需要将LoginAction内所有出现CustomerDao的地方改为CustomerDao2。非常麻烦。这就是耦合性高的代价。

那么如何降低耦合性呢,我们可以将变化较大的类改成变化较小的接口,然后在action中通过一个工厂类来返回相应的对象。将代码修改为:


publicinterface ICustomerDao {   publicboolean getCustomerByAccount();       } 
publicclass CustomerDao implements ICustomerDao {  publicboolean getCustomerByAccount(){/* 代码 */ }      }  //工厂类publicclass DaoFactory {  publicstatic ICustomerDao getCustomerDao() {  returnnew CustomerDao();          }      } 
publicclass LoginAction {  publicvoid execute() {              ICustomerDao icdao = DaoFactory.getCustomerDao();  boolean b = icdao.getCustomerByAccount();  // 判断          }      }

在上面的程序中,如果需要做CustomerDao的切换,如,从CustomerDao改为CustomerDao2,就只需让CustomerDao2实现"ICustomerDao"接口,然后修改工厂的方法,而不用修改LoginAction内的代码。

LoginAction只需要认识ICustomerDao接口,不需要认识具体的实现类。而接口修改的概率比实现类要低得多。因此,这样编写就降低了程序的耦合性,是一个比较好的方法。

但是,以上方法也不是没有修改的余地。当Dao进行切换时,还是需要修改BeanFactory的源代码,能否避免这个问题呢?可以对DaoFactory进行改进,使得它能为所有类服务。代码如下


publicinterface ICustomerDao {   publicboolean getCustomerByAccount();       } 
publicclass CustomerDao implements ICustomerDao {  publicboolean getCustomerByAccount() {/* 代码 */          }      } 
publicclass BeanFactory {  publicstatic Object getBean(String className) {  return Class.forName(className).newInstance();          }      } 
publicclass LoginAction {  publicvoid execute() {              ICustomerDao icdao = (ICustomerDao)BeanFactory.getBean("CustomerDao");  boolean b = icdao.getCustomerByAccount();  // 判断          }      }

此处使用了反射机制。修改后,需要切换的时候只需在LoginAction内改变类名,工厂内就会自动生成对象返回给LoginAction。在 LoginAction中,由于类名是字符串,因此,就可以将该字符串写在一个配置文件内,让LoginAction读入,这样,当 CustomerDao类名需要切换时,就直接修改配置文件就行了。不用改源代码,模块之间的耦合就完全由配置文件决定。

这种设计方法有一个好处是,BeanFactory类的通用性很强,就可以将其框架化。因此,框架化之后,对象的生成由框架参考配置文件进行,和具 体实现类的源代码无关,将对象生成的控制权由修改不方便的源代码转变为修改相对方便的配置文件与几乎不进行修改的框架进行,这就是控制反转 (Inverse Of Control,IOC)的原理。

Spring 依赖注入(控制反转)介绍的更多相关文章

  1. Helloworld之Spring依赖注入/控制反转(DI/IoC)版

    Helloworld之Spring依赖注入/控制反转(DI/IoC)版 作者:雨水, 日期:2014-10-29 摘要:本文主要用于培训刚開始学习的人理解Spring中的依赖注入的基本概念. 先介绍依 ...

  2. Spring 依赖注入控制反转实现,及编码解析(自制容器)

    定义: 在运行期,由外部容器动态的将依赖对象动态地注入到组件中. 两种方式: 手工装配 -set方式 -构造器 -注解方式 自动装配(不推荐) 1利用构造器 2set方法注入 dao: package ...

  3. C#依赖注入控制反转IOC实现详解

    原文:C#依赖注入控制反转IOC实现详解 IOC的基本概念是:不创建对象,但是描述创建它们的方式.在代码中不直接与对象和服务连接,但在配置文件中描述哪一个组件需要哪一项服务.容器负责将这些联系在一起. ...

  4. PHP关于依赖注入(控制反转)的解释和例子说明

    PHP关于依赖注入(控制反转)的解释和例子说明 发表于2年前(2014-03-20 10:12)   阅读(726) | 评论(1) 8人收藏此文章, 我要收藏 赞2 阿里云双11绽放在即 1111 ...

  5. spring依赖注入(反转控制)

    SPRING依赖注入机制(反转控制)解析 Spring能有效地组织J2EE应用各层的对象.不管是控制层的Action对象,还是业务层的 Service对象,还是持久层的DAO对象,都可在Spring的 ...

  6. Spring进阶之路(1)-Spring核心机制:依赖注入/控制反转

    原文地址:http://blog.csdn.net/wangyang1354/article/details/50757098 我们经常会遇到这样一种情景,就是在我们开发项目的时候经常会在一个类中调用 ...

  7. Benefits of Using the Spring Framework Dependency Injection 依赖注入 控制反转

    小结: 1. Dependency Injection is merely one concrete example of Inversion of Control. 依赖注入是仅仅是控制反转的一个具 ...

  8. laravel5.2总结--服务容器(依赖注入,控制反转)

    1.依赖 我们定义两个类:class Supperman 和 class Power,现在我们要使用Supperman ,而Supperman 依赖了Power class Supperman { p ...

  9. 依赖注入&控制反转

    IoC——Inversion of Control  控制反转DI——Dependency Injection   依赖注入 要想理解上面两个概念,就必须搞清楚如下的问题: 参与者都有谁? 依赖:谁依 ...

  10. MVC 依赖注入/控制反转

    http://www.cnblogs.com/cnmaxu/archive/2010/10/12/1848735.html http://www.cnblogs.com/artech/archive/ ...

随机推荐

  1. git :.gitigrone文件不生效的解决办法

    真正的原因是.gitignore只能忽略那些尚未被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的.一个简单的解决方法就是先把本地缓存删除(改变成未track状 ...

  2. JMeter学习笔记(十一) 关于 CSV Data Set Config 的 Sharing mode 对取值的影响

    关于 CSV Data Set Config 的一些介绍之前已经梳理过了,可以参考: https://www.cnblogs.com/xiaoyu2018/p/10184127.html . 今天主要 ...

  3. Python全栈工程师(元组、字典)

     ParisGabriel     感谢 大家的支持  你们的阅读评价就是我最好的更新动力  我会坚持吧排版做的越来越好        每天坚持 一天一篇 点个订阅吧  灰常感谢    当个死粉也阔以 ...

  4. 孤荷凌寒自学python第二十天python的匿名函数与偏函数

    孤荷凌寒自学python第二十天python的匿名函数与偏函数 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) Python为使函数的使用更加方便高效,可以使用两种特殊的函数简化语句书写. 一 ...

  5. PHP面向对象 封装与继承

    知识点: PHP封装三个关键词: 一.public 公有的,被public修饰的属性和方法,对象可以任意访问和调用 二.private 私有的,被private修饰的属性和方法,只能在类内部的方法可以 ...

  6. 分享下自己一直用的.NET SQLSERVER 封装类下自己写的DataHelper 操作类

    一,概述: 这个DataHelper 类是基于我上个博客里发的SQLDataAccess 这个类做的一个简单的封装,为了结合自己的实体类和数据操作而产生的. 这里面用了  属性类,反射.还有 数据类型 ...

  7. 全球顶尖的内容创作引擎,Unity为创造而生

    5月11日晚,Unite Beijing 2018 Keynote主题演讲于国家会议中心圆满落幕.今年的Keynote主题演讲汇聚了12位重量级嘉宾,为参会者呈现出了一场属于Unity 2018的技术 ...

  8. POJ 3304 Segments | 线段相交

    #include<cstdio> #include<algorithm> #include<cstring> #define N 105 #define eps 1 ...

  9. Codeforces 359D Pair of Numbers | 二分+ST表+gcd

    题面: 给一个序列,求最长的合法区间,合法被定义为这个序列的gcd=区间最小值 输出最长合法区间个数,r-l长度 接下来输出每个合法区间的左端点 题解: 由于区间gcd满足单调性,所以我们可以二分区间 ...

  10. 洛谷 P2329 [SCOI2005]栅栏 解题报告

    P2329 [SCOI2005]栅栏 题目描述 农夫约翰打算建立一个栅栏将他的牧场给围起来,因此他需要一些特定规格的木材.于是农夫约翰到木材店购买木材.可是木材店老板说他这里只剩下少部分大规格的木板了 ...