动态加载类(动态加载DLL文件)
本人刚刚开始编写程序不久,开发中发现一非常好的方法。大家共享。
我们在编写程序的时候经常会遇到这样的情况:程序中要用到某种计算,而且这种计算的计算方式很多,我们不得不在编写程序时就要考虑的十分全面,将各种情况到考虑到。但是这样做又非常的费力,因为我们无法预测到程序编好后,还会出现什么样的计算方式。如果计算方式是在交付给客户后,客户新提出的我们就不得不将新的计算方式写人程序中,然后重新编译,再交给客户。这样做是相当麻烦的,而且只为了这么一小段程序,就要重新编译整个工程,似乎代价也挺大的。
使用MS.NET中System.Reflection中的一些方法,可以帮助我们很好的解决上面的问题。
首先,在遇到上面提出的问题的时候,我们先要进行一下分析,这种计算需要一些什么参数?在不同的计算方式中,它们共同的参数是什么?不同的计算方式中特有的参数是否可以通过共有的参数计算出来,或是通过其它方法获得?分析完后,提取出可用的共同参数。
接下来,我们就可以编写计算方法了。将这种计算的每一种方式都写成一个DLL一个类中的方法,并将其编译为一个DLL文件。MS.NET中,类的格式要定死,也就是说编写的类的namespace和class要一样,类中的方法名称也必须是一样的。而且,方法的参数就是上面所说的共同参数。
然后,将编译好的DLL文件放在同一文件夹内,随程序一起发布就可以了。
在程序中可以这样处理所要用到的不同计算方式:给每一种计算方式起一个名字(客户能够明白的),然后将这些名字放在下拉列表框的text属性中,并将对应的DLL文件名放在下拉列表框的value属性中。这样,用户选择不同的计算方式就可以调用不同DLL文件中的计算方法了。
下面是一个简单的示例:
我将计算方式的名字和DLL文件名放在一个xml文件中,程序加载时将它们读取到下拉列表框中。方法如下:(asp.net中)
// 在此处放置用户代码以初始化页面
if(Page.IsPostBack==false)
{
// 页面首次加载时读取XML文件
System.Xml.XmlDocument xmlDoc=new System.Xml.XmlDocument();
System.Xml.XmlNode xmlNd;
int i;
xmlDoc.Load(Server.MapPath("MyConfig.xml"));
xmlNd=xmlDoc.SelectSingleNode("//dllfile");
// 将读出的XML文件的有关内容写入下拉列表框中
for(i=0;i<xmlNd.SelectNodes("field").Count;i++)
{
ListItem it=new ListItem();
it.Text=xmlNd.SelectNodes("field").Item(i).Attributes["text"].Value;
it.Value=xmlNd.SelectNodes("field").Item(i).Attributes["filename"].Value;
this.ddlType.Items.Add(it);
}
}
然后,在输入完参数之后,可以使用下面的代码来完成计算并将结果显示出来。我写的方法是计算后返回一个DataTable。
DataTable dt=null;
// 加载类所在的dll文件
Assembly ass=Assembly.LoadFrom(Server.MapPath(this.ddlType.SelectedItem.Value));
// 获取类型
Type tp=ass.GetType("MyNamespace.MyClass");
// 获取方法
MethodInfo mi=tp.GetMethod("MyMethodl");
// 创建实例
Object obj=System.Activator.CreateInstance(tp);
// 付值参数数组(要求类型一致性)
Object[] objArray=new object[7];
objArray[0]=Convert.ToDouble(this.textBox1.Text);
objArray[1]=Convert.ToInt32(this.textBox2.Text);
objArray[2]=Convert.ToDouble(this.textBox3.Text);
// 调用方法
dt=(DataTable)mi.Invoke(obj,objArray);
// 有返回值就绑定到DataGrid
if(dt!=null)
{
this.grdResult.DataSource=dt;
this.grdResult.DataBind();
}
作者:绿荫(yistudio)
E-mail:yistudio@hotmail.com