NET插件系统之一,开头:MEF的一些疑问和相关思考

简介:

实现可扩展的软件系统是我一直的目标和想法。可扩展性显然属于动态编程的范畴。因此,几个月来我在业余时间会抽空学习插件系统。  

我参考了博客园的几篇插件式系统的文章。知道了实现插件系统有以下的核心流程:

      1. 定义插件接口,并在各个功能组件中实现这些接口

  2. 在主程序中,通过遍历所需目录下的dll文件,查询实现该接口的type,从而通过createInstance方法实现其动态创建,并加入到主程序插件列表。下面的代码展示了该功能。

复制代码
    public void GetAllPluginInPath(string Path, string InterFaceName)
{
string[] DllFileName = Directory.GetFileSystemEntries(Path);
Type[] types;
foreach (string file in DllFileName)
{

if (System.IO.Path.GetExtension(file) == ".dll")
{
Assembly assembly;

try
{
assembly = Assembly.LoadFrom(file);
}
catch
{
continue;
}

try
{
types = assembly.GetTypes();
}
catch (Exception ex)
{
continue;
}

foreach (Type type in types)
{
if (type.GetInterface(InterFaceName) != null && !type.IsAbstract)
{
object thisObject = Activator.CreateInstance(type);


IXPlugin rc1 = thisObject as IXPlugin;


//如果要在启动时被加载
if (rc1 != null && rc1.isStartLoaded)

{
AddPlugin(rc1);
}


}
}
}
}

}
复制代码

 

      这个流程其实很简单,我也比较方便的实现了自制的插件系统。 但问题随之而来:

      1. 如果该系统是一棵插件树,那么显然我需要不止一次查询所有dll文件,并查询所有type,这会带来显著的性能问题。

      2. 如果某类型不需要在启动时就实例化,那么我可以存储该类型,在需要的时候实现调用。

    3. 最核心也是最大的问题: 插件之间的相互访问如何解决,当前我只能采用 从插件列表中找到该引用,然后将其强制类型转换到所需的插件样式。但显然,这种做法很不好,不符合插件隔离,而且必须添加该项目引用。

      4. 我希望能在不实例化该类的前提下获得对象的某些属性, 比如, 一个游戏列表,它会提供这些游戏的名称,图片和相关信息。但这些数据才能如何获得?虽然有attribute,但它所提供的功能显然有限。

 

      后期,我采用了微软官方的MEF插件框架,我看了金旭亮老师的相关著作,并仔细阅读了Bēniaǒ成长笔记 关于MEF编程的部分,并手动实现之,虽然觉得足够方便,但带来的问题也更多:

      1. MEF可以方便的实现插件组件,不需要手动硬编码,但其中的控制权限显然不在用户,有些选项虽然开放,但你很难控制。虽然我知道有Lazy泛型,但如哪些方法在什么时候实例化还是很难保证。我并不需要在任何时候都保留所有插件的实例对象,而希望在需要的时候实例化或销毁它,可惜MEF未能提供。 

      2. 使用MEF后,必须强制将实现插件的各个组件版本升到.net 4.0, 虽然不是太难的事情,但却需要客户端更多的部署。

  3. MEF依旧没有解决插件间通信的问题,它仅仅为你提供了插件的集合,但组件间的事件,通信方法却只字未提。 如果是这样的话,它的功能岂不是太简单?

      4.MEF是否有性能问题?它的实现机制显然是反射和attribute, 但搜索目录和某一程序集并实例化的性能如何呢?我没有做过详细对比....

       结合前面,使用import和export关键字实现的MEF插件虽然很high,但带来的问题也绝对不少。   但实际上,我们手动实现一个比MEF更灵活的系统也不是一件太难的事情,而增加的代码量实际并不多,也不用加入这个依赖库。 于是,MEF的价值又有多大呢?

      

       我非常崇拜VS或者eclipse这样大型软件所实现的插件系统,主核心完全无法知道将来会有什么功能加入,但其可扩展性,性能,结构清晰程度都是像我这样的菜鸟无法企及的。是不是有更复杂的机制,如 事件管道来实现这些功能呢?我不知道。

       当然有很多类型的插件系统,比如MAF,我未曾做深入研究,是因为实在学习成本高昂,时间有限,但实际上特别希望能学习这些插件系统的精髓之处。

       非常希望有大牛能解决我的以下问题。

       1.  各插件之间能够解除引用依赖的事件通知方法。 调用难道我要把所有的功能都写入接口么?这显然不现实。

       2. 如何提升插件搜索组件的速度和性能?

       3. 如何在不实例化该类的前提下获得对象的某些属性?之所以不想实例化,是因为该对象可能比较庞大,如果对象很多,这会带来显著的性能问题

       有任何问题随时欢迎交流!

       

      


作者:热情的沙漠
出处:http://www.cnblogs.com/buptzym/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。


 本文转自FerventDesert博客园博客,原文链接:http://www.cnblogs.com/buptzym/archive/2011/12/09/2282746.html,如需转载请自行联系原作者

目录
打赏
0
0
0
0
20
分享
相关文章
.NET使用Umbraco CMS快速构建一个属于自己的内容管理系统
.NET使用Umbraco CMS快速构建一个属于自己的内容管理系统
48 12
一款基于 .NET + Blazor 开发的智能访客管理系统
一款基于 .NET + Blazor 开发的智能访客管理系统
基于.NET8+Vue3开发的权限管理&个人博客系统
基于.NET8+Vue3开发的权限管理&个人博客系统
.NET技术的独特魅力与优势,涵盖高效的开发体验、强大的性能表现、高度的可扩展性及丰富的生态系统等方面,展示了其在软件开发领域的核心竞争力
本文深入探讨了.NET技术的独特魅力与优势,涵盖高效的开发体验、强大的性能表现、高度的可扩展性及丰富的生态系统等方面,展示了其在软件开发领域的核心竞争力。.NET不仅支持跨平台开发,具备出色的安全性和稳定性,还能与多种技术无缝集成,为企业级应用提供全面支持。
93 3
.NET 8.0 开源在线考试系统(支持移动端)
【10月更文挑战第27天】以下是适用于 .NET 8.0 的开源在线考试系统(支持移动端)的简介: 1. **基于 .NET Core**:跨平台,支持多种数据库,前后端分离,适用于多操作系统。 2. **结合 Blazor**:使用 C# 开发 Web 应用,支持响应式设计,优化移动端体验。 3. **基于 .NET MAUI**:跨平台移动应用开发,一套代码多平台运行,提高开发效率。 开发时需关注界面设计、安全性与稳定性。
104 4
从0到1搭建权限管理系统系列三 .net8 JWT创建Token并使用
【9月更文挑战第22天】在.NET 8中,从零开始搭建权限管理系统并使用JWT(JSON Web Tokens)创建Token是关键步骤。JWT是一种开放标准(RFC 7519),用于安全传输信息,由头部、载荷和签名三部分组成。首先需安装`Microsoft.AspNetCore.Authentication.JwtBearer`包,并在`Program.cs`中配置JWT服务。接着,创建一个静态方法`GenerateToken`生成包含用户名和角色的Token。最后,在控制器中使用`[Authorize]`属性验证和解析Token,从而实现身份验证和授权功能。
489 3
|
5月前
|
.NET 隐藏/自定义windows系统光标
【10月更文挑战第20天】在.NET中,可以使用`Cursor`类来控制光标。要隐藏光标,可将光标设置为`Cursors.None`。此外,还可以通过从文件或资源加载自定义光标来更改光标的样式。例如,在表单加载时设置`this.Cursor = Cursors.None`隐藏光标,或使用`Cursor.FromFile`方法加载自定义光标文件,也可以将光标文件添加到项目资源中并通过资源管理器加载。这些方法适用于整个表单或特定控件。
CodeMaid:一款基于.NET开发的Visual Studio代码简化和整理实用插件
CodeMaid:一款基于.NET开发的Visual Studio代码简化和整理实用插件
120 0

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等