惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Simon Willison's Weblog
Simon Willison's Weblog
P
Privacy International News Feed
www.infosecurity-magazine.com
www.infosecurity-magazine.com
T
Troy Hunt's Blog
Hacker News - Newest:
Hacker News - Newest: "LLM"
Attack and Defense Labs
Attack and Defense Labs
S
Secure Thoughts
V2EX - 技术
V2EX - 技术
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
O
OpenAI News
Cloudbric
Cloudbric
Google Online Security Blog
Google Online Security Blog
Schneier on Security
Schneier on Security
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Help Net Security
Help Net Security
Cyberwarzone
Cyberwarzone
G
GRAHAM CLULEY
L
Lohrmann on Cybersecurity
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
Spread Privacy
Spread Privacy
NISL@THU
NISL@THU
N
News and Events Feed by Topic
T
Tenable Blog
S
Security @ Cisco Blogs
N
News and Events Feed by Topic
The Hacker News
The Hacker News
C
CXSECURITY Database RSS Feed - CXSecurity.com
宝玉的分享
宝玉的分享
月光博客
月光博客
酷 壳 – CoolShell
酷 壳 – CoolShell
美团技术团队
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google DeepMind News
Google DeepMind News
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
Tailwind CSS Blog
V
Visual Studio Blog
P
Proofpoint News Feed
Webroot Blog
Webroot Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
博客园 - 三生石上(FineUI控件)
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
Jina AI
Jina AI
雷峰网
雷峰网
T
The Blog of Author Tim Ferriss
Hugging Face - Blog
Hugging Face - Blog
腾讯CDC
L
LangChain Blog
The Register - Security
The Register - Security
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
博客园 - 聂微东

博客园 - YiStudio

在Word中插入图片 DataGridView多列排序 将Word嵌入到自己的程序中 一个非常不错的压缩组件 免费的国产报表Grid++Reprot 使用NSIS制作安装包(2) 使用NSIS制作安装包(1) SharpDevelop2.0 用Firebird .NET Data Provider编写.NET应用程序(2) 用Marathon管理Firebird数据库(2) 用Firebird .NET Data Provider编写.NET应用程序(1) 用Marathon管理Firebird数据库(1) Firebird简介 NDoc修改手记(三) NDoc修改手记(二) NDoc修改手记(一) WebForm中将DataGrid中导出数据的方法 FxCop EXCEL2003中使用XML
动态加载类(动态加载DLL文件)
YiStudio · 2005-05-20 · via 博客园 - YiStudio

我们在编写程序的时候经常会遇到这样的情况:程序中要用到某种计算,而且这种计算的计算方式很多,我们不得不在编写程序时就要考虑的十分全面,将各种情况到考虑到。但是这样做又非常的费力,因为我们无法预测到程序编好后,还会出现什么样的计算方式。如果计算方式是在交付给客户后,客户新提出的我们就不得不将新的计算方式写人程序中,然后重新编译,再交给客户。这样做是相当麻烦的,而且只为了这么一小段程序,就要重新编译整个工程,似乎代价也挺大的。
   
使用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();
   }