Linux中国 Linux中国门户站!
设为主页 设为主页
收藏本站 收藏本站
 
当前位置 :首页 ->编程语言 ->ASP.NET ->正文

利用.net反射动态调用指定程序集的中的方法

来源:Linuxdby.com 作者:Webmaster 时间:2007-06-04 点击: [收藏] [投稿]

    每个.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();

 如果您对本文有任何疑问或者建议,请到讨论区发表您的意见: >> 论坛入口 <<



上一篇:ASP.NET随机码生成示例   下一篇:RSS 文档中 language 标签中的可选值

文章评论】 【收藏本文】 【推荐好友】 【打印本文】 【我要投稿】 【论坛讨论
更多相关文章
Power by linux-cn.com 粤ICP备05006655号