如何解决使用MEF为同一导入提供不同的值
| 这个问题与MEF的用法有关。 我想在这两种情况下为同一导入提供不同的值[Export(\"A1\",typeof(IA))]
[Export(\"A2\",typeof(IA))]
class A : IA
{
[Import(\"B\")]
public IB B;
}
[PartCreationPolicy(CreationPolicy.NonShared)]
[Export(typeof(IA))]
class A : IA
{
[Import]
public IB B;
}
在上述两种情况下,我都想用不同的值来满足IB
的导入,这是我在第一类导出中执行的操作
var a1 = Container.GetExportedValue<IA>(\"A1\");
var a2 = Container.GetExportedValue<IA>(\"A1\");
或者在第二次出口中
var a1 = Container.GetExportedValue<IA>();
var a2 = Container.GetExportedValue<IA>();
我希望Aa1
和a2
的两个实例具有不同的of1ѭ值。我不想使用ImportMany
,因为那样的话我必须决定选择哪一个,而我又想将逻辑放在class8ѭ类之外。
与这些导出有关的两种情况是,我希望有一个通用的通用视图,以与实现某些接口的不同类型的视图模型一起使用,以及提供要使用不同配置参数配置的某些服务的类的不同实例。
解决方法
也许您正在寻找这样的东西?
public class AExporter
{
[Export(\"A1\",typeof(IA)]
public IA A1
{
get
{
return new A(this.B1);
}
}
[Export(\"A2\",typeof(IA)]
public IA A2
{
get
{
return new A(this.B2);
}
}
[Import(\"B1\",typeof(IB))]
public IB B1 { private get; set; }
[Import(\"B2\",typeof(IB))]
public IB B2 { private get; set; }
}
但是,MEF并非真正针对这种对合成的细粒度控制而设计的。您可以尝试使用Autofac之类的替代方法,该替代方法与MEF集成良好。
,我不完全了解您要执行的操作,但是我认为您可以通过在IB导入中指定非共享的创建策略来执行此操作。
[Import(RequiredCreationPolicy=CreationPolicy.NonShared)]
public IB B;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。