怎么理解依赖注入
Posted 开拓丿飞
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么理解依赖注入相关的知识,希望对你有一定的参考价值。
作者:anderson93
链接:https://www.zhihu.com/question/32108444/answer/121881566
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
假如有一个 船(C)类 ,一个 桨(J) 类,
如果船要干什么事,肯定需要浆的参与。所以是十分 “依赖”浆;
出了需求需要重构:这时候我们需要控制浆的长度为10在构造方法中。我们需要这么写;
此时如下:不管你怎么改浆,改成100米与船都无关,他只要依赖Human,
一千个船修改浆需求我只修改Human类中方法便可。(核心业务逻辑需要依赖的类实例化交给第三方类来实现注入。)
说通俗点,咱们要解耦啊。
MVP模式就是解耦比较全面的设计模式模型
class C{ J j = new J() ; }
出了需求需要重构:这时候我们需要控制浆的长度为10在构造方法中。我们需要这么写;
class C{ J j = new J(10) ; }
一个特性需要修改浆构造方法,又需要修改船其中的new J()方法。这时候就设计者就思考,为什么我们加入一个特性需要更改两个类中代码(这也就是耦合度高)!
所以我们要解耦要依赖注入;
- 构造方法注入
class C{ J j public c(J j){ this.j = j; }; }
- 工厂模式注入
Class Human { J j =new J(); J getJ(){ return j ; } }
一千个船修改浆需求我只修改Human类中方法便可。(核心业务逻辑需要依赖的类实例化交给第三方类来实现注入。)
Class C { J j ; Human h = new Human; j=Human.getJ(); }
- 框架注入(本质还是工厂设计模式的具体实现)
本质也是第三方依赖注入,但是这个第三方可以脱离类。将对象依赖映射信息存储在容器一般为.xml 或者特定的对象中,并实现动态的注入。你需要我就给你哦。
为什么要有依赖注入(一种设计代码模式),因为我们要控制反转(设计代码的思路)。为什么控制反转。因为我们软件设计需要符合软件设计原则依赖倒置(设计代码原则),单一职责原则。说通俗点,咱们要解耦啊。
MVP模式就是解耦比较全面的设计模式模型
以上是关于怎么理解依赖注入的主要内容,如果未能解决你的问题,请参考以下文章
spring练习,在Eclipse搭建的Spring开发环境中,使用set注入方式,实现对象的依赖关系,通过ClassPathXmlApplicationContext实体类获取Bean对象(代码片段