依赖注入 – 在运行时使用Open Generics和Type指定的Autofac
发布时间:2020-12-13 20:11:20 所属栏目:百科 来源:网络整理
导读:该文档指出Autofac支持开放式泛型,我能够在如下基本情况下注册和解决: 注册: builder.RegisterGeneric(typeof(PassThroughFlattener)) .As(typeof(IFlattener)) .ContainerScoped(); 解决: var flattener = _container.ResolveIFlattenerAddress(); 上面
该文档指出Autofac支持开放式泛型,我能够在如下基本情况下注册和解决:
注册: builder.RegisterGeneric(typeof(PassThroughFlattener<>)) .As(typeof(IFlattener<>)) .ContainerScoped(); 解决: var flattener = _container.Resolve<IFlattener<Address>>(); 上面的代码工作得很好.但是,假设我不知道在运行之前提供给IFlattener的类型,我想做这样的事情: object input = new Address(); var flattener = (IFlattener)_container.Resolve(typeof(IFlattener<>),new TypedParameter(typeof(IFlattener<>),input.GetType())); 这可以用AutoFac吗?我从使用StructureMap获得了以下想法: http://structuremap.sourceforge.net/Generics.htm 我正在努力实现本文中概述的相同目标.
Autofac当然可以实现这一点.在“注册时间”,这是你基本上做的:
>注册开放通用类型(PassThroughFlattener<>) 在“解决时间”,您将: >解决方法 这是一个(希望)工作样本: var openType = typeof(IFlattener<>); var builder = new ContainerBuilder(); builder.RegisterGeneric(typeof(PassThroughFlattener<>)).As(openType); builder.Register<AddressFlattener>().As<IFlattener<Address>>(); builder.Register<Func<object,IFlattener>>(context => theObject => { var concreteType = openType.MakeGenericType(theObject.GetType()); return (IFlattener) context.Resolve(concreteType,new PositionalParameter(0,theObject)); }); var c = builder.Build(); var factory = c.Resolve<Func<object,IFlattener>>(); var address = new Address(); var addressService = factory(address); Assert.That(addressService,Is.InstanceOfType(typeof(AddressFlattener))); var anything = "any other data"; var anyService = factory(anything); Assert.That(anyService,Is.InstanceOfType(typeof(PassThroughFlattener<string>))); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |