- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
(我知道其他 MEF/MAF 问题,但这是一个更具体的问题)
我想创建一个基本上只是一个简单的加载项主机、GUI 和设置的 WPF 应用程序。所有实际工作将由一个或多个插件完成。它们之间不需要通信,主应用程序会向它们发送用户输入/命令,它们会返回一些结果(例如,要呈现的 WPF UI 元素)。
现在,由于应用程序的核心将基于插件,我需要选择一种好的方式来管理它们。我希望能够在运行时加载/卸载/重新加载它们(例如,当找到并下载更新时)。为了稳定性和安全性,它们可能应该在自己的应用程序域和/或进程中运行。
通过一些研究和实验,我得出了三个选择:
System.Addin (MAF): 看来这可以满足我的所有需求。有一个管道允许多个版本的 API 同时运行以实现兼容性等。但是除非我遗漏了一些我需要多次创建 API 的东西——主机和插件 View 、契约(Contract)和契约(Contract)的两个适配器。此外,周围的信息和资源很少(与 MEF 相比),而且大多数文章都是几年前的文章。我担心它会慢慢消亡,不想将它用于新项目。
MEF:这个看起来比较简单,但也感觉有很多我无法控制的魔力,而且层没有像 MAF 那样分离.我只想要一个小库,您可以链接到一个新项目,实现接口(interface)并完成插件。
手动加载:最后一个选项是手动扫描文件夹中的 .dll,使用反射查找插件类并创建实例。虽然这是可行的,但我宁愿使用一些框架,也不愿手动加载程序集、创建单独的进程/应用程序域等。
那么,哪种应用程序最适合这种应用程序,或者我错过了什么?
最佳答案
MEF 绝对是三者中最简单的选择。它在设计时确实考虑到了这种确切的场景(可扩展应用程序)。
其实就是Visual Studio使用的“插件”机制,它是一个WPF应用程序。您需要做的就是让您的“插件”实现一个接口(interface)或派生自一个已知的基类,然后添加 [Export]
属性。如果将它的程序集添加到主应用程序的目录中,则该类型可以由主应用程序一步完成[Import]
。完成这项工作涉及的工作很少。
这是我的建议,除非有充分的理由选择不同的选项。 MAF 有更多的隔离支持,但更难使用,而且大多数隔离功能在 WPF 应用程序中将不可用,因为 WPF 中的 UI 在任何情况下都不可能真正是隔离代码。
关于c# - 可扩展的 WPF 应用程序 - MEF、MAF 或简单加载?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3111714/
我有此消息的CompositionException异常: “类型为'SomeService'的ComposablePart不能重新组合,因为它处于无效状态。只有在已经完全预览或组合的情况下,才可以重
我目前正在调查 MEF,以了解我们公司正在编写的软件的某种插件子系统的可行性。我想到的第一个问题是了解 MEF 组件对应用程序加载时间的影响。 此外,如果这很重要,是否有可能在运行时完全加载这些组件?
我开始学习,MEF 和其中一件重要的事情是我可以用导出属性标记一些项目(类、属性、方法),以便任何想要使用它的人都会在实例变量上创建导入属性并使用它。这种映射是如何发生的,何时发生?导入是按需延迟发生
我知道 MEF CompositionContainer 创建并保留类的实例。我不知道在什么情况下 CompositionContainer 在其内部有一个类实例。 任何人都可以列出在 Composi
我需要向我们现有的代码添加一些扩展点,并且我一直将 MEF 视为一种可能的解决方案。我们有一个 IRandomNumberGenerator 接口(interface),带有一个我们希望可交换的默认实
我看到 MEF ( MEF Codeplex site ) 上的新功能仍在继续工作,并且他们正在发布 MEF 2 beta 版本,但是他们没有关于新功能正在试验/探索/构建的任何体面的文档? 那么,作
我有一个对象实例,并且我希望最终得到一个包含该对象实例并导出为特定接口(interface)类型的 MEF 目录。我怎样才能做到这一点? TypeCatalog在这里似乎不起作用,因为(a)它创建一个
我计划在 ASP.NET 中使用 MEF,以深入了解 CompositionContainer 的线程安全性。 我的第一种方法将不同的 CompositionContainer 与每个请求相关联,但我
这类似于我的代码的外观 var catalog = new AssemblyCatalog(typeof(Program).Assembly); _container = new Compositio
我正在使用 MEF 和 System.ComponentModel.Composition.dll 来加载一些 dll。 我正在做类似的事情: AggregateCatalog catalog = n
我认识到,MEF 仅限于 metro 风格的应用程序。没有容器了,那么我怎样才能获得特定的导出值,如 ILogger logger = container.GetExportedValues(); ?
据我所知,为了使导入/导出属性相互正确连接,我必须对具有这些属性的每个新实例调用 compositionContainerInstance.Compose(...)。 是否可以自动发生这种情况,这样我
所以不使用 ExportMetadata 属性,为什么不直接扩展接口(interface)呢? 最佳答案 如果您通过 MEF 导入 Lazy<> 内容,则无需实例化对象即可查看元数据。 关于mef -
我正在尝试将 signalR 集线器作为使用 MEF 的插件的一部分。但是在 List<> 对象上调用 ImportMany 然后在 Global.asax 文件的 Application_Start
我找不到它!? 最佳答案 ExportFactory不是桌面 MEF 的一部分(但是 - 截至目前,它仅针对 Silverlight 发布)。看起来它将包含在 MEF 2 中。 与此同时,Glenn
安装包含 MEF 组件的 VSIX 项目时,Visual Studio 如何查找 MEF 组件?我知道常规方法可能是添加包含 MEF 部分的 dll 目录的目录。 Visual Studio 如何知道
是否可以将 IronPython 类声明为“导出”,从而将它们添加到 MEF 目录中主机 C# 应用程序可以导入吗? 我真的找不到任何具体的例子,只是猜测。 以下是我如何手动加载实现 .NET 接口(
MEF 团队一直在说它是关于插件模型的。那么,我们是在谈论 UI 插件吗?我们如何在非 UI 代码中使用这些东西? 我下载了代码,示例都是关于 GUI 的。我猜错了吗? 最佳答案 伊利亚 MEF 绝对
我有一个选项卡式应用程序,我希望用户能够在其中搜索某个人,然后在新 View 中显示此人的详细信息。用户应该能够为不同的人打开多个人的详细信息 View 。 我有点不确定我是否遵循了创建新 View
在 What's new in .NET 4.5微软表示 MEF 现在将支持“多范围”。这是什么意思?我在任何地方都找不到关于它的文档。 最佳答案 我相信你的问题在这个博客中得到了完整的回答:http
我是一名优秀的程序员,十分优秀!