依赖注入优缺点分析

Posted 李雷

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了依赖注入优缺点分析相关的知识,希望对你有一定的参考价值。

背景

项目开发要求:

1、增加程序重用

2、模块功能单一

3、方便测试

4、需求变更,减少程序开发

实际应用场景

以两种日志记录和数据库使用两种场景来分析

1、日志记录:有时需要调试分析,需要记录日志信息,这时可以采用输出到控制台、文件、数据库、远程服务器等;假设最初采用输出到控制台,直接在程序中实例化ILogger logger = new ConsoleLogger(),但有时又需要输出到别的文件中,也许关闭日志输出,就需要更改程序,把ConsoleLogger改成FileLogger或者NoLogger,此时不断的更改代码,就显得心里不好了,如果采用依赖注入,就显得特别舒畅。

2、数据库操作:几乎任何项目都离不开数据库的使用,数据库种类特别多:oracle、mysql、sqlserver、informix、postgresql... ...,数据库语法也不尽相同,假如开始使用的是oracle,有一天改成了postgresql,这时采用依赖注入就显得圆润的多。

优点

  • 传统的代码,每个对象负责管理与自己需要依赖的对象,导致如果需要切换依赖对象的实现类时,需要修改多处地方。同时,过度耦合也使得对象难以进行单元测试。
  • 依赖注入把对象的创造交给外部去管理,很好的解决了代码紧耦合(tight couple)的问题,是一种让代码实现松耦合(loose couple)的机制。
  • 松耦合让代码更具灵活性,能更好地应对需求变动,以及方便单元测试。

缺点

  在java语言中基本采用反射的方式来实现依赖注入,在一定程度会影响性能

以上是关于依赖注入优缺点分析的主要内容,如果未能解决你的问题,请参考以下文章

依赖注入与服务位置

java八股系列——依赖注入的方式

Spring IoC 依赖注入源码分析

Spring依赖注入和循环依赖问题分析

Spring依赖注入和循环依赖问题分析

ABP源码分析六:依赖注入的实现