我试图在我定义的类中获取导出属性,但我认为缺少一些我不知道的东西。这是我的Handler类:
public class Handler
{
public string Message { get; private set; }
public void Create(string msg)
{
Message = msg;
}
}
我的HandlerUser类是:
public class HandlerUser
{
[Export(typeof(Handler))]
public Handler MyHandler { get; set; }
public string Name { get; set; }
public HandlerUser() { MyHandler = new Handler(); }
}
在我的program.cs中,我有:
var catalogs = new AggregateCatalog();
var catalog = new ApplicationCatalog();
catalogs.Catalogs.Add(catalog);
CompositionContainer pluginsCompositionContainer = new CompositionContainer(catalogs);
HandlerUser u1 = new HandlerUser();
u1.MyHandler.Create("U1");
HandlerUser u2 = new HandlerUser();
u2.MyHandler.Create("U2");
var exports = pluginsCompositionContainer.GetExports<Handler>();
Console.Write(exports.Count());
我希望看到2个导出,并且他们应该将“U1”,“U2”作为他们的消息,但我只看到一个,并且消息为空。我无法弄清楚缺少什么,我很简单想要在代码中导出Every Handler
,并且能够做一些逻辑。任何帮助都会很棒。
答案 0 :(得分:1)
使用MEF时,您无法导出某些类的属性或方法(作为类型),您需要导出类本身,因此您的代码应如下所示:
[Export(typeof(Handler))]
public class HandlerUser : Handler
{
public string Name { get; set; }
public HandlerUser() : base()
{
}
}
但是既然你正在使用MEF,这意味着你正在尝试为你的应用程序添加可扩展性,考虑到这一点,我会把“处理”一个接口而不是一个类,所以这样任何人都可以实现他们想要的方式,他们只需要实现界面。
在这种情况下,就像:
public interface IHandler
{
string Message { get; }
public void Create(string msg);
}
[Export(typeof(Handler))]
public class HandlerUser : IHandler
{
public string Name { get; set; }
public string Message { get; private set;}
public HandlerUser()
{
}
public void Create(string msg)
{
this.Message = msg
}
}
修改强>
我已经更新了答案以明确MEF如何与导出一起使用,实际上您可以导出属性,但不能在问题的上下文中导出。执行此操作时,您将通过属性名称“Handler”导出,而不是像Class定义中那样导出类型(Handler)。属性和方法导出是一个很酷的功能,但有一些限制(方法导出的最大参数数量是4!),在可能的情况下更喜欢类导出。
有关使用MEF导出的更多信息,请参见here
答案 1 :(得分:0)
您只看到一次导出的原因是CompositionContainer
不知道您自己创建的其他两个对象。
要让CompositionContainer使用另外两个Handlers
,请将每个HandleUser传递给CompositionContainer.ComposeParts方法。这个将把处理程序注册到容器中。
pluginsCompositionContainer.ComposeParts(u1);
pluginsCompositionContainer.ComposeParts(u2);
然后当你得到出口时,你会注意到它们不是两个(正如你最初预期的那样),而是三个。您自己创建并使用CompositionContainer.ComposeParts
注册到容器的两个加上容器自动创建的容器(实际上它是Lazy<Handler>
)。最后一个是您在示例代码中看到的那个。当您尝试访问此特定导出值时,容器将创建HandlerUser
的实例,然后将引用返回到Handler
。