依赖注入 – 为什么不通过你的IoC容器?

前端之家收集整理的这篇文章主要介绍了依赖注入 – 为什么不通过你的IoC容器?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在这个AutoFac“最佳实践”页面( http://code.google.com/p/autofac/wiki/BestPractices)上,他们说:

不要通过集装箱
将组件访问容器,或将其存储在公共静态属性中,或者在全局“IoC”类上使Resolve()等功能可用,从而达不到使用依赖注入的目的。这样的设计与服务定位器模式更相似。
如果组件对容器有依赖关系,请查看它们如何使用容器检索服务,并将这些服务添加到组件的(依赖注入)构造函数参数中。

那么,一个组件“动态地”实例化另一个组件的更好方法是什么呢?他们的第二段不包括“可能”需要创建的组件将取决于系统的状态的情况。或者当组件A需要创建X个组件B时。

要抽出另一个组件的实例化,可以使用Factory模式:
public interface IComponentBFactory
{
    IComponentB CreateComponentB();
}

public class ComponentA : IComponentA
{
    private IComponentBFactory _componentBFactory;

    public ComponentA(IComponentBFactory componentBFactory)
    {
        _componentBFactory = componentBFactory;
    }

    public void Foo()
    {
        var componentB = _componentBFactory.CreateComponentB();

        ...
    }
}

然后实现可以向IoC容器注册

容器是组合对象图的一种方式,但它并不是唯一的方法。这是一个实现细节。保持没有这种知识的对象将它们从基础设施问题中解脱出来。它也使得他们不必知道要解决哪个版本的依赖关系。

猜你在找的设计模式相关文章