问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

请问下依赖注入的三种方式的区别

发布网友 发布时间:2022-04-22 11:16

我来回答

1个回答

热心网友 时间:2023-10-12 05:32

Type1 接口注入

我们常常借助接口来将调用者与实现者分离。如:

public class ClassA {
private InterfaceB clzB;
public init() {
Ojbect obj =
Class.forName(Config.BImplementation).newInstance();
clzB = (InterfaceB)obj;
}
……
}

上面的代码中,ClassA依赖于InterfaceB的实现,如何获得InterfaceB实现类的实例?传统的方法是在代码中创建InterfaceB实现类的实例,并将起赋予clzB。

而这样一来,ClassA在编译期即依赖于InterfaceB的实现。为了将调用者与实现者在编译期分离,于是有了上面的代码,我们根据预先在配置文件中设定的实现类的类名,动态加载实现类,并通过InterfaceB强制转型后为ClassA所用。

这就是接口注入的一个最原始的雏形。

而对于一个Type1型IOC容器而言,加载接口实现并创建其实例的工作由容器完成,如J2EE开发中常用的Context.lookup(ServletContext.getXXX),都是Type1型IOC的表现形式。

Apache Avalon是一个典型的Type1型IOC容器。

Type2构造子注入

构造子注入,即通过构造函数完成依赖关系的设定,如:

public class DIByConstructor {
private final DataSource dataSource;
private final String message;
public DIByConstructor(DataSource ds, String msg) {
this.dataSource = ds;
this.message = msg;
}
……
}

可以看到,在Type2类型的依赖注入机制中,依赖关系是通过类构造函数建立,容器通过调用类的构造方法,将其所需的依赖关系注入其中。

PicoContainer(另一种实现了依赖注入模式的轻量级容器)首先实现了Type2类型的依赖注入模式。

Type3设值注入

在各种类型的依赖注入模式中,设值注入模式在实际开发中得到了最广泛的应用(其中很大一部分得力于Spring框架的影响)。

在笔者看来,基于设置模式的依赖注入机制更加直观、也更加自然。Quick Start中的示例,就是典型的设置注入,即通过类的setter方法完成依赖关系的设置。

几种依赖注入模式的对比总结

接口注入模式因为具备侵入性,它要求组件必须与特定的接口相关联,因此并不被看好,实际使用有限。

Type2 构造子注入的优势:

1、“在构造期即创建一个完整、合法的对象”,对于这条Java设计原则,Type2无疑是最好的响应者。

2、避免了繁琐的setter方法的编写,所有依赖关系均在构造函数中设定,依赖关系集中呈现,更加易读。

3、由于没有setter方法,依赖关系在构造时由容器一次性设定,因此组件在被创建之后即处相对“不变”的稳定状态,无需担心上层代码在调用过程中执行setter方法对组件依赖关系产生破坏,特别是对于Singleton模式的组件而言,这可能对整个系统产生重大的影响。

4、同样,由于关联关系仅在构造函数中表达,只有组件创建者需要关心组件内部的依赖关系。对调用者而言,组件中的依赖关系处于黑盒之中。对上层屏蔽不必要的信息,也为系统的层次清晰性提供了保证。

5、通过构造子注入,意味着我们可以在构造函数中决定依赖关系的注入顺序,对于一个大量依赖外部服务的组件而言,依赖关系的获得顺序可能非常重要,比如某个依赖关系注入的先决条件是组件的DataSource及相关资源已经被设定。

Type3设值注入的优势

1、对于习惯了传统JavaBean开发的程序员而言,通过setter方法设定依赖关系显得更加直观,更加自然。

2、如果依赖关系(或继承关系)较为复杂,那么Type2模式的构造函数也会相当庞大(我们需要在构造函数中设定所有依赖关系),此时Type3模式往往更为简洁。

3、对于某些第三方类库而言,可能要求我们的组件必须提供一个默认的构造函数(如Struts中的Action),此时Type2类型的依赖注入机制就体现出其局限性,难以完成我们期望的功能。

可见,Type2和Type3模式各有千秋,而Spring、PicoContainer都对Type2和Type3类型的依赖注入机制提供了良好支持。这也就为我们提供了更多的选择余地。理论上,以Type2类型为主,辅之以Type3类型机制作为补充,可以达到最好的依赖注入效果,不过对于基于Spring Framework开发的应用而言,Type3使用更加广泛。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
女生多大后可以不在长身高? 如何不用软件把手机投屏到电脑上手机屏幕怎样投放到电脑上 战时拒绝、故意延误军事订货罪既遂的处罚? 战时故意延误军事订货罪处罚标准 名师1+1导读方案:汤姆·索亚历险记目录 三星sm-g7200打开微信慢,无法正常收看,网速不慢。 笔记本电脑如何调亮屏幕亮度 大伙说说洗衣机要不要带烘干好 热烘干洗衣机怎么样 ef英语哪个好 在spring中依赖注入工具类有什么作用 spring 中依赖注入的思想? asp.net mvc 依赖注入有什么用 依赖注入到底是为了解决什么问题的 angularjs 依赖注入有什么好处 java依赖注入是什么?有什么用处吗?该在什么时候用? spring ioc依赖注入有几种 每种区别,优缺点 Spring依赖注入有什么好处 spring 依赖注入有什么好处 spring中的依赖注入有什么用? “读读、议议、讲讲、练练”教学法是什么? spring的依赖注入到底有什么优势 依赖注入究竟有什么好处? 把支付宝微信权电话薄权限解除分期乐还能扣钱么 用支付宝充话费显示陌生人帐号,但电话号码沒错 支付宝通知使用权限怎么开启 支付宝实名认证的手机号权限受限的原因 登录支付宝手机号被限权怎么办? 下载支付宝必须充许直接呼叫电话号码功能吗? 支付宝怎么设置电话本呢? 依赖注入是怎么回事 什么是依赖注入? spring的依赖注入是什么意思 在中国养宠物浣熊合法吗? 本田CRV车载导航如何升级 本田crv导航版导航如何升级 本田crv如何升级导航 《爱宠大机密》中雪球兔子说的浣熊撒谎是什么梗? 东风本田crv2014款导航仪地图如何更新 神武手游浣熊大师怎么样 宠物图鉴大全 10年的 本田CRV导航更新 改装本田crv安卓导航仪一体机怎么升级系统 本田crv车载内存卡中导航更新 求2010本田crv原车高德导航升级 本田CRV 车载互联网网络3G如何升级4G? 东风本田10款CRV原厂导航怎么升地图 2010款本田CRV 2.4 原厂车载导航仪怎么升级? 2013crv东风本田原车导航怎样换地图 移动宽带一年多少钱 装的移动宽带,自带wifi性能不行,我又买了个 TP路由器当wifi用我该怎么设置路由器