为了账号安全,请及时绑定邮箱和手机立即绑定

通过构造函数或属性设置器进行依赖注入?

通过构造函数或属性设置器进行依赖注入?

侃侃无极 2019-09-19 09:32:19
我正在重构一个类并为它添加一个新的依赖项。该类目前正在构造函数中使用其现有依赖项。因此,为了保持一致性,我将参数添加到构造函数中。当然,对于单元测试,有一些子类加上甚至更多,所以现在我正在玩改变所有构造函数的游戏来匹配,并且它需要很长时间。这让我觉得使用带有setter的属性是获得依赖关系的更好方法。我认为注入的依赖项不应该是构造类实例的接口的一部分。您添加了一个依赖项,现在所有用户(子类和任何直接实例化您的用户)突然知道它。这感觉就像打破了封装。这似乎不是现有代码的模式,所以我希望找出一般的共识是什么,构造函数与属性的优缺点。使用属性设置器更好吗?
查看完整描述

3 回答

?
翻过高山走不出你

TA贡献1875条经验 获得超3个赞

这要看情况 :-)。

如果没有依赖项,类无法完成其工作,则将其添加到构造函数中。该类需要新的依赖项,因此您希望您的更改能够破坏事物。此外,创建一个未完全初始化的类(“两步构造”)是反模式(IMHO)。

如果类可以在没有依赖项的情况下工作,那么setter就可以了。


查看完整回答
反对 回复 2019-09-19
?
绝地无双

TA贡献1946条经验 获得超4个赞

一般优选的方法是尽可能多地使用构造器注入。

构造函数注入准确地说明了对象正常运行所需的依赖项 - 没有什么比新建一个对象更令人讨厌,并且在调用一个方法时因为没有设置某个依赖项而使它崩溃。构造函数返回的对象应处于工作状态。

尝试只有一个构造函数,它保持设计简单并避免歧义(如果不是人类,DI容器)。

当你在他的书“.NET中的依赖注入”中使用Mark Seemann所称的本地默认值时,你可以使用属性注入:依赖是可选的,因为你可以提供一个很好的工作实现但是想让调用者指定一个不同的实现需要。

(以下的答案)


我认为如果注入是强制性的,构造函数注入会更好。如果这会添加太多构造函数,请考虑使用工厂而不是构造函数。

如果注射是可选的,或者如果你想在中途改变它,那么setter注射是很好的。我一般不喜欢制定者,但这是一个品味问题。


查看完整回答
反对 回复 2019-09-19
  • 3 回答
  • 0 关注
  • 600 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信