每个.net程序集除了代码外都额外包含了元数据。元数据包括了程序集本身的信息,比如版本号,引用了什么程序集,所有类型的信息,包括其方法、属性、字段。使用.net反射,可以在运行时读取这些信息,并且可以动态地调用方法。 项目快完了,终于有时间来写blog了,, 做一个动态调用程序集指定方法的例子。 项目1(Demo)中包含一个Test类,Test类中写了一个getList方法,这个方法返回的数据是手工加入的。源代码如下: 项目1 using System; using System.Collections.Generic; using System.Text; using System.Data; namespace Demo { public class Test { public DataTable getList(string id) { DataTable dt = new DataTable(); dt.Columns.Add(new DataColumn("id")); dt.Columns.Add(new DataColumn("name")); dt.Columns.Add(new DataColumn("sex")); DataRow dr = dt.NewRow(); dr["id"] = "zl"; dr["name"] = "张铃"; dr["sex"] = "男"; dt.Rows.Add(dr); dr = dt.NewRow(); dr["id"] = "zl"; dr["name"] = "李四"; dr["sex"] = "女"; dt.Rows.Add(dr); return dt; } } } 项目2(DemoXml)中包含一个Test类,Test类中写了一个getList方法,这个方法返回的数据是从数据库读取的。源代码如下: 项目2 using System; using System.Collections.Generic; using System.Text; using System.Data; using System.Data.SqlClient; using System.Xml; namespace DemoXml { public class Test { private SqlConnection cn; public DataTable getList(string id) { try { cn = new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings["pubs"]); SqlCommand cmd = new SqlCommand(); SqlDataAdapter da = new SqlDataAdapter(); cmd.CommandText = "SELECT au_id as id,au_lname as name,au_fname as sex from authors"; cmd.CommandType = CommandType.Text; cmd.Connection = cn; da.SelectCommand = cmd; DataTable dt = new DataTable(); da.Fill(dt); return dt; } catch (Exception ex) { throw new ApplicationException("出现异常:"+ex.Message+ex.StackTrace); } finally { cn.Close(); cn = null; } } } } |