gpt4 book ai didi

c# - IOC 容器实际上为我做了什么?

转载 作者:太空狗 更新时间:2023-10-29 22:17:03 25 4
gpt4 key购买 nike

所以我已经完全重构为构造函数注入(inject),现在我有一个类似于此的 Bootstrap 类:

var container = new UnityContainer();
container.RegisterType<Type1, Impl1>();
container.RegisterType<Type2, Impl2>();
container.RegisterType<Type3, Impl3>();
container.RegisterType<Type4, Impl4>();

var type4Impl = container.Resolve((typeof)Type4) as Type4;
type4Impl.Run();

我盯着它看了一秒钟,然后才意识到 Unity 真的没有为我做任何特别的事情。省略 ctor sigs,上面可以写成:

Type1 type1Impl = Impl1();
Type2 type2Impl = Impl2();
Type3 type3Impl = Impl3(type1Impl, type2Impl);
Type4 type4Impl = Impl4(type1Impl, type3Impl);
type4Impl.Run();

构造函数注入(inject)重构很棒,真正打开了代码的可测试性。但是,我在这里怀疑 Unity 的用处。我意识到我可能以有限的方式使用框架(即不在任何地方注入(inject)容器,在代码而不是 XML 中配置,没有利用生命周期管理选项),但我没有看到它在这个例子中实际上有什么帮助.我读过不止一条评论,认为 DI 最好简单地用作一种模式,而无需容器。这是这种情况的一个很好的例子吗?该解决方案还提供了哪些我错过的其他好处?

最佳答案

我发现当容器中有许多相互依赖的类型时,DI 容器会变得有值(value)。正是在这一点上,容器的自动连接功能大放异彩。

如果您发现在从容器中取出对象时引用的是容器,那么您实际上是在遵循服务定位器模式。

关于c# - IOC 容器实际上为我做了什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7001545/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com