本文实例讲述了C#动态加载dll扩展系统功能的方法。分享给大家供大家参考。具体分析如下:
动态加载dll,主要是为了扩展功能,增强灵活性而实现的。主要通过xml配置,来获取所有要动态加载的dll,然后通过反射机制来调用dll中的类及其方法。
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Reflection; using System.Text; using System.Threading.Tasks; namespace DynamicLoadDLL { /// <summary> /// 动态加载dll /// </summary> public class LoadDLL { private Assembly ass = null; /// <summary> /// 加载dll /// </summary> /// <param name="dllPath">dll文件路径</param> public LoadDLL(string dllPath) { this.ass = Assembly.LoadFrom(dllPath); //利用dll的路径加载(fullname) } /// <summary> /// 返回反射的dll /// </summary> /// <returns></returns> public Assembly GetAssembly() { return this.ass; } /// <summary> /// 获取所有类名 /// </summary> /// <returns></returns> public Type[] GetClass() { return ass.GetTypes(); } /// <summary> /// 获取程序集下的所有文件名 /// </summary> /// <returns></returns> public Module[] GetModules() { return ass.GetModules(); } /// <summary> /// 获取程序集清单文件表中的文件 /// </summary> /// <returns></returns> public FileStream[] GetFiles() { return ass.GetFiles(); } } }
这个是加载dll的,然后返回一个Assembly类型的一个反射值,如果该dll中有多个命名空间和类的话,就只用一个Assembly类型的一个反射值即可以完成调用,否则每次生成一个类,都需要反射一次。IO操作相对而言是比较耗费CPU,影响效率的。
using System; using System.Collections.Generic; using System.Linq; using System.Reflection; using System.Text; using System.Threading.Tasks; namespace DynamicLoadDLL { /// <summary> /// 加载类 /// </summary> public class LoadClass { private static LoadClass dlc = null; private Type type; private object obj = null; //实例 /// <summary> /// 加载dll /// </summary> /// <param name="ass">dll引用</param> /// <param name="nameSpace">类的命名空间</param> /// <param name="classPath">类名称</param> private LoadClass(Assembly ass, string nameSpace, string classPath) { //加载dll后,需要使用dll中某类. type = ass.GetType(nameSpace + "." + classPath); //利用类型的命名空间和名称获得类型 //需要实例化类型,才可以使用, //参数可以人为的指定,也可以无参数,静态实例可以省略 obj = Activator.CreateInstance(type); //利用指定的参数实例话类型 } /// <summary> /// 加载dll /// </summary> /// <param name="ass">dll引用</param> /// <param name="nameSpace">类的命名空间</param> /// <param name="classPath">类名称</param> public static LoadClass GetInstance(Assembly ass, string nameSpace, string classPath) { if (dlc == null) { dlc = new LoadClass(ass, nameSpace, classPath); } return dlc; } /// <summary> /// 获取属性集 /// </summary> /// <returns>返回属性值</returns> public PropertyInfo[] GetAttrs() { //调用类型中的某个属性: PropertyInfo[] prop = type.GetProperties(); //通过属性名称获得属性 //返回属性集 return prop; } public MethodInfo[] GetMethods() { //调用类型中的方法: MethodInfo[] method = type.GetMethods(BindingFlags.NonPublic); //获得方法集 //返回方法集 return method; } /// <summary> /// 获取属性值 /// </summary> /// <param name="attrName">属性名称</param> /// <returns>返回属性值</returns> public object GetAttrValue(string attrName) { //调用类型中的某个属性: PropertyInfo prop = type.GetProperty(attrName); //通过属性名称获得属性 //返回属性值 return prop.GetValue(obj); } /// <summary> /// 设置属性值 /// </summary> /// <param name="attrName">属性名称</param> /// <returns>返回属性值</returns> public void SetAttrValue(string attrName, string attrValue) { //调用类型中的某个属性: PropertyInfo prop = type.GetProperty(attrName); //通过属性名称获得属性 //返回属性值 prop.SetValue(obj, attrValue); } /// <summary> /// 执行类方法 /// </summary> /// <param name="methodName">方法名称</param> /// <param name="paras">参数</param> /// <param name="types">参数类型</param> /// <returns></returns> public object GetMethod(string methodName, object[] paras,Type[] types) { //调用类型中的某个方法: MethodInfo method = type.GetMethod(methodName,types); //通过方法名称获得方法 //执行方法 return method.Invoke(obj, paras); } } }
上面这个类根据dll反射值,命名空间和类名,反射出一个具体的类,还提供了属性和方法的调用方法。很方便。
这些是我在研究插件编程时,顺带研究的,不太深入。
希望本文所述对大家的C#程序设计有所帮助。
本文向大家介绍C#实现动态加载dll的方法,包括了C#实现动态加载dll的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#实现动态加载dll的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的C#程序设计有所帮助。
12.4 透明装饰模式与半透明装饰模式 装饰模式虽好,但存在一个问题。如果客户端希望单独调用具体装饰类新增的方法,而不想通过抽象构件中声明的方法来调用新增方法时将遇到一些麻烦,我们通过一个实例来对这种情况加以说明: 在Sunny软件公司开发的Sunny OA系统中,采购单(PurchaseRequest)和请假条(LeaveRequest)等文件(Document)对象都具有显示功能,现在要为其增
12.3 完整解决方案 为了让系统具有更好的灵活性和可扩展性,克服继承复用所带来的问题,Sunny公司开发人员使用装饰模式来重构图形界面构件库的设计,其中部分类的基本结构如图12-4所示: 图12-4 图形界面构件库结构图 在图12-4中,Component充当抽象构件类,其子类Window、TextBox、ListBox充当具体构件类,Component类的另一个子类Compone
12.2 装饰模式概述 装饰模式可以在不改变一个对象本身功能的基础上给对象增加额外的新行为,在现实生活中,这种情况也到处存在,例如一张照片,我们可以不改变照片本身,给它增加一个相框,使得它具有防潮的功能,而且用户可以根据需要给它增加不同类型的相框,甚至可以在一个小相框的外面再套一个大相框。 装饰模式是一种用于替代继承的技术,它通过一种无须定义子类的方式来给对象动态增加职责,使用对象之间的关联关系取
尽管目前房价依旧很高,但还是阻止不了大家对新房的渴望和买房的热情。如果大家买的是毛坯房,无疑还有一项艰巨的任务要面对,那就是装修。对新房进行装修并没有改变房屋用于居住的本质,但它可以让房子变得更漂亮、更温馨、更实用、更能满足居家的需求。在软件设计中,我们也有一种类似新房装修的技术可以对已有对象(新房)的功能进行扩展(装修),以获得更加符合用户需求的对象,使得对象具有更加强大的功能。这种技术对应于一
SDK对外开放了一个可自定义的协议NtalkerChatDelegate,如果客户想进行自定义实现接口,必须遵守此协议,初始化小能类的时候设置其delagate为实现代理接口方法的类,然后实现相应的接口。其中提供了以下几个接口: 深度自定义控件接口,详细调用细节,请参照demo。 一、自定义消息发送 二、查询历史咨询列表 三、设置超媒体自定义参数 四、+号功能区的扩展功能 五、商品条自定义 六、设
一、发送文本消息到聊窗内 二、返回按钮的点击监听 三、结束会话按钮的点击监听 四、超媒体点击事件的监听 五、+号功能区的扩展功能 六、商品条自定义 七、导航栏自定义
QueyList是完全模块化的设计,拥有强大的可扩展性。 使用bind()方法绑定一个功能函数到QueryList对象,实现轻量级的功能扩展。bind()方法的第一个参数是绑定的函数名,第二个参数是一个匿名的功能函数,这个功能函数的$this对象指向的是当前的QueryList实例对象,所以在这个功能函数中可以直接通过$this来调用QueryList的方法。 例子 注册一个自定义的http网络操