加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 使用autofac解析方法内部的类实例

发布时间:2020-12-16 01:27:52 所属栏目:百科 来源:网络整理
导读:使用下面的这个PipelineX类,有没有办法解决应用于pipline的过滤器而不注入autofac容器并调用_container.Resolve(); public class PipelineXT : FilterBaseT,IPipelineXT{ private readonly IContainer _container; public PipelineX(IContainer container) {
使用下面的这个PipelineX类,有没有办法解决应用于pipline的过滤器而不注入autofac容器并调用_container.Resolve();

public class PipelineX<T> : FilterBase<T>,IPipelineX<T>
{
    private readonly IContainer _container;

    public PipelineX(IContainer container)
    {
        _container = container;
    }
    protected override T Process(T input)
    {
        return input;
    }

    public PipelineX<T> FilterBy<X>()
    {
        var filter = _container.Resolve(typeof(X)) as IFilter<T>;
        Register(filter);
        return this;
    }                             
}

解决方法

为了避免将Autofac用作服务定位器,您可以在其中注册自己的工厂方法,在这种情况下:

builder.Register<Func<Type,object>>((c,p) =>
{
    var context = c.Resolve<IComponentContext>();
    return type => context.Resolve(type);
});

并在您的PipelineX类中使用它,如下所示:

private readonly Func<Type,object> filterFactory;

public PipelineX(Func<Type,object> filterFactory)
{
    this.filterFactory = filterFactory;
}

protected override T Process(T input)
{
    return input;
}

public PipelineX<T> FilterBy<X>()
{
    var filter = this.filterFactory(typeof(X)) as IFilter<T>;
    Register(filter);
    return this;
}

考虑:这只删除了对Autofac容器的硬引用,它仍然使用一个抽象对象工厂,该工厂不够自我解释,应该由自定义过滤器工厂或选择器实现替换.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读