C#反射之基础应用实例总结

本文将反射的东西整理了一下 , 提供了最全面的东西 , 当然也是基础的东西 ,
在学好了这一切的基础上 , 大家可以学习反射的具体插件等应用 首先我们建立一个类库 , 将它生成为 reflectPrj .dll,

代码如下:

using System;
using System.Collections.Generic;
using System.Text;
 
namespace reflectPrj
{
    /// <summary>
    /// 接口
    /// </summary>
    public interface Interface1
    {
        int Add(int num);
        int Add();
    }
    /// <summary>
    /// 用来被测试的类
    /// </summary>
    public class ReflectTest : Interface1
    {
  
        public string writea;
 
        public string WriteA
        {
            get { return writea; }
            set { writea = value ; }
        }
 
        public string Writeb;
 
        public string WriteB
        {
            get { return Writeb; }
            set { Writeb = value ; }
        }
 
        public ReflectTest()
        {
            this .WriteA = "WriteA" ;
            this .WriteB = "WriteB" ;
        }
 
        public ReflectTest(string a, string b)
        {
            this .WriteA = a;
            this .WriteB = b;
        }
 
        public int Add()
        {
            return 100;
        }
        public int Add(int num)
        {
            return num;
        }
 
        public string WriteString(string a,string b)
        {
             return " 欢迎你," + a + "------" +b;
      
        }
 
        public static string WriteName(string s)
        {
            return " 欢迎光临," + s;
        }
 
        public string WriteNoPara()
        {
            return " 你使用的是无参数方法!" ;
        }
 
        private string WritePrivate()
        {
            return " 私有类型的方法!" ;
        }
    }
}

之后再建立一个项目引入该 reflectPrj .dll

代码如下:

using System;
using System.Collections.Generic;
using System.Text;
using reflectPrj;
using System.Threading;
using System.Reflection;
 
namespace reflectPrjTest
{
    class MyReflectTest
    {
        // 建立委托
        delegate string TestDelegate (string a,string b);
 
        static void Main(string [] args)
        {
            Assembly assembly= Assembly .Load("reflectPrj" );
 
            foreach (Type var in assembly.GetTypes())
            {
                Console .WriteLine(var.Name);// 显示dll 下所有的类
            }
 
            //*******************************************************
 
            Module [] modules = assembly.GetModules();
 
            foreach (Module module in modules)
            {
                Console .WriteLine("module( 模块/ 组件) 名:" +module.Name);
            }
 
            //*******************************************************
            // 得到具体的类的类型
            Type a = typeof (reflectPrj.ReflectTest );
          
            Console .WriteLine(a.Name);
 
            //*******************************************************
            //A------ 创建类型的实例----> 此处是由带参的构造函数的来得到的实例
            string [] paras ={"aaa" ,"bbb" };
            // 创建该类的实例,后面的paras 为有参构造函数的参数----> 此obj 即是类型a 的一个实例
            // 此实例调用的是一个带参的构造函数
            object obj = Activator .CreateInstance(a,paras);
 
            // 得到对象的属性
            Console .WriteLine(" 得到对象a 的属性:" );
            foreach (object var in a.GetProperties())
             {
                 Console .WriteLine(var.ToString());
             }
          
            MethodInfo [] miArr = a.GetMethods();
 
            Console .WriteLine(" 显示所有的共有方法:" );
            // 显示所有的共有方法
            foreach (MethodInfo method in miArr)
            {
                Console .WriteLine(method.Name);
            }
          
            //************************************************************
            // 显示具体的方法
            Console .WriteLine(" 显示具体的方法!" );
 
            //1. 带参的方法的使用
            MethodInfo mi = a.GetMethod("WriteString" );
            string miReturn =(string ) mi.Invoke(obj, new object [] { " 使用的是带参数的非静态方法" , "2" });
 
            Console .WriteLine("---" +mi.Name+" 返回值:" +miReturn);
 
            //2. 不带参数的方法调用
            Console .WriteLine(" 不带参数的方法的调用:" );
            MethodInfo miNopara = a.GetMethod("WriteNoPara" );
 
            string miNoparaReturn = (string )miNopara.Invoke(obj, null );
 
            Console .WriteLine("---" +miNoparaReturn);
 
            //3. 私有类型方法的使用
            Console .WriteLine(" 私有类型方法的使用:" );
            MethodInfo miPrivate = a.GetMethod("WritePrivate" ,BindingFlags .Instance | BindingFlags .NonPublic);
 
            string miPrivateReturn = (string )miPrivate.Invoke(obj, null );
 
            Console .WriteLine("---" +miPrivateReturn);
 
            Console .WriteLine("*********************** 属性的使用**********************" );
 
            //4. 得到对象的属性
            PropertyInfo [] propertys = a.GetProperties(BindingFlags .Instance | BindingFlags .NonPublic |BindingFlags .Public);
         
            //5. 显示所有属性名
            Console .WriteLine(" 对象的所有属性名如下:" );
            foreach (PropertyInfo pro in propertys)
            {
                //Console.WriteLine(pro.Name);
                 // 获取属性最初的值
                Console .WriteLine(pro.Name+" :" +pro.GetValue(obj,null ));
 
                // 给属性重新赋值
                pro.SetValue(obj, " 张三丰" , null );
                Console .WriteLine(pro.Name + " :" + pro.GetValue(obj, null ));
 
             }
        
            //6. 获取指定的属性,并赋值
            PropertyInfo propertyInfo=a.GetProperty("WriteA" ,BindingFlags .Instance| BindingFlags .NonPublic|BindingFlags .Public);
 
            propertyInfo.SetValue(obj, " 郁金香" , null );
 
            Console .WriteLine(propertyInfo.Name+" :" +propertyInfo.GetValue(obj,null ));
 
            Console .WriteLine("*********************FieldInfo--- 公开字段的使用***********************" );
            //7. 字段的使用----> 只能获取公开字段
            FieldInfo f1 = a.GetField("writea" ,BindingFlags .Instance| BindingFlags .NonPublic| BindingFlags.Public);
 
            Console .WriteLine(f1.GetValue(obj));
 
            try
            {
                reflectPrj.ReflectTest test = new ReflectTest ("Marry" , "Jack" );
 
                Type myReflect = typeof (ReflectTest );
 
                FieldInfo field1= myReflect.GetField("writea" , BindingFlags .Public | BindingFlags .NonPublic |BindingFlags .Instance);
 
                Console .WriteLine(field1.GetValue(test));
            }
            catch (Exception ex)
             {
                Console .WriteLine(ex.Message);
            }
 
            //*******************************************************
            //8. 构造函数的使用
            Console .WriteLine(" 获得构造函数的形式" );
            ConstructorInfo [] cis =a.GetConstructors();
            foreach (ConstructorInfo ci in cis)
            {
                Console .WriteLine(" 构造函数的形式:" +ci.ToString());// 获得构造函数的形式
                Console .WriteLine(" 构造函数名称:" +ci.Name);
            }
 
            // 打印带参构造函数的形式
            ConstructorInfo ascSingle = a.GetConstructor(new Type [] { typeof (string ),typeof (string )});
 
            Console .WriteLine(ascSingle.ToString());
 
            //****************************************************
            //9. 工厂模式
            Console .WriteLine(a.Name);
            reflectPrj.Interface1 reflectObj2 = (Interface1 )assembly.CreateInstance("reflectPrj.ReflectTest" );
            reflectPrj.ReflectTest reflectObj1 = (ReflectTest )assembly.CreateInstance("reflectPrj.ReflectTest" );
 
            Console .WriteLine(reflectObj2.Add());// 典型的工厂模式,在后续真正应用中使用的是接口中的方法(而接口又由实现接口的类来实现)
            Console .WriteLine(reflectObj1.WriteNoPara());
 
            //10 工厂模式--- 方法的重载
            int num = 300;
            Console .WriteLine(reflectObj1.Add(300));
 
            Console .WriteLine(" 工厂模式的再一次实现!" );
            foreach (Type type in assembly.GetTypes())
            {
                if (type.GetInterface("reflectPrj.Interface1" )!=null )
                {
                    // 由接口的实现类来实现该接口
                    reflectPrj.Interface1 interfaceObj3 = (Interface1 )Activator .CreateInstance(a);
 
                    Console .WriteLine(interfaceObj3.Add());
                    Console .WriteLine(interfaceObj3.Add(600));
                }
            }
            //****************************************************
            //11. 动态创建委托的简单例子---> 将委托绑定到目标方法上
            TestDelegate myMothod = (TestDelegate )Delegate .CreateDelegate(typeof (TestDelegate ),obj,mi);
 
            Console .WriteLine(myMothod.Invoke("Tom" , "Jack" ));
 
            //****************************************************
            //B----------. 无参构造函数的使用
            Console .WriteLine(" 无参构造函数的使用!" );
 
            //objNonePara 是由ReflectTest 类的构造函数所产生的对象
            object objNonePara = Activator .CreateInstance(a);
 
            string info=((reflectPrj.ReflectTest )objNonePara).WriteNoPara();
 
            Console .WriteLine(info);
 
            PropertyInfo proWriteA = a.GetProperty(((ReflectTest )objNonePara).WriteA);
            Console .WriteLine(proWriteA.GetValue(objNonePara,null ));
 
            proWriteA.SetValue(objNonePara, " 小小郁金香" , null );
 
            Console .WriteLine(proWriteA.GetValue(objNonePara, null ));
 
            //C:--------- 再次用带参的构造函数来产生实例
            ReflectTest objPara =(ReflectTest ) Activator .CreateInstance(a, new object [] {" 小郁" ," 来吧" });
            Console .WriteLine(objPara.WriteA+"/t" +objPara.WriteB);
            Console .WriteLine(objPara.WriteNoPara());
 
            // 调用带参的方法
            Console .WriteLine(objPara.WriteString(" 大郁" , " 回家吧!" ));
            MethodInfo myMi=a.GetMethod("WriteString" );
 
             // 利用委托动态的将将委托绑定的指定的方法
            myMothod=(TestDelegate )Delegate .CreateDelegate(typeof (TestDelegate ),objPara,myMi);
            Console .WriteLine(myMothod.Invoke(" 过年啦" , " 牛年快乐啊!" ));
 
            // 屏幕暂停
            Console .ReadLine();
        }
     }
}

希望本文所述对大家的C#程序设计有所帮助。

(0)

相关推荐

  • C#中使用反射遍历一个对象属性及值的小技巧

    总结: 对应某个类的实例化的对象tc, 遍历获取所有属性(子成员)的方法(采用反射): 复制代码 代码如下: Type t = tc.GetType();//获得该类的Type //再用Type.GetProperties获得PropertyInfo[],然后就可以用foreach 遍历了 foreach (PropertyInfo pi in t.GetProperties()) {     object value1 = pi.GetValue(tc, null));//用pi.GetVal

  • C#定义简单的反射工厂实例分析

    本文实例讲述了C#定义简单的反射工厂用法.分享给大家供大家参考.具体分析如下: 首先,定义一个水果抽象类,代码如下: class Fruit { //定义虚方法 public virtual void Eating() { Console.WriteLine("水果有各种吃法..."); } } 然后,实例化几个水果类,代码如下: class Banana : Fruit { public override void Eating() { Console.WriteLine("

  • .net中 关于反射的详细介绍

    概述反射• 通过反射可以提供类型信息,从而使得我们开发人员在运行时能够利用这些信息构造和使用对象. • 反射机制允许程序在执行过程中动态地添加各种功能.  运行时类型标识 •运行时类型标识(RTTI),可以在程序执行期间判定对象类型.例如使用它能够确切地知道基类引用指向了什么类型对象.•运行时类型标识,能预先测试某个强制类型转换操作,能否成功,从而避免无效的强制类型转换异常. •在c#中有三个支持RTTI的关键字:is . as  .typeof. 下面依次介绍他们  is运算符: 通过is运算

  • c#反射调用方法示例

    获取方法的相关信息的两种形式 反射是一种允许用户获得类信息的C#功能,Type对象映射它代表的底层对象: 在.Net 中, 一旦获得了Type对象,就可以使用GetMethods()方法获取此类型支持的方法列表:该方法的两种形式: MethodInfo [] GetMethods() MethodInfo [] GetMethods(BindingFlags bindingflas)  :它的参数带有一些限制 BindingFlags  是一个枚举 枚举成员 [DeclaredOnly,Inst

  • C#泛型和反射实例解析

    C#中的泛型和反射经常是一起工作的,因此这里就一次性的加以介绍了. 由于c#是强类型语言,一般来说函数的返回类型和参数的类型都是一早写好的,这也就造成了很多时候不像js那样方便使用,不够灵话. 因此就有了这个泛型,它可以让你的函数和参数在调用的时候才决定类型.如下例所示: public T abc<T>(T word) { return word; return default(T); //关键字default可以对引用类型返回nullAble,int类型返回0,初始化一个T的感觉啦 } ab

  • dotNet中的反射用法入门教程

    本文实例讲述了dotNet中的反射用法.分享给大家供大家参考,具体如下: 参考MSDN: ms-help://MS.VSCC.2003/MS.MSDNQTR.2003FEB.2052/cpguide/html/cpcondiscoveringtypeinformationatruntime.htm 提纲: 1. 什么是反射 2. 命名空间与装配件的关系 3. 运行期得到类型信息有什么用 4. 如何使用反射获取类型 5. 如何根据类型来动态创建对象 6. 如何获取方法以及动态调用方法 7. 动态创

  • 通俗易懂的C#之反射教程

    前言 之所以要写这篇关于C#反射的随笔,起因有两个: 第一个是自己开发的网站需要用到 其次就是没看到这方面比较好的文章. 所以下定决心自己写一篇,废话不多说开始进入正题. 前期准备 在VS2012中新建一个控制台应用程序(我的命名是ReflectionStudy),这个项目是基于.net 4.0.接着我们打开Program.cs文件,按照如下在Program中写一个我们自己的类: 复制代码 代码如下: public class RefClass         {             pri

  • C#通过反射创建自定义泛型

    本文以实例形式讲述了C#通过反射创建自定义泛型的实现方法,分享给大家供大家参考.具体如下: 比如有这样一个泛型:Demo.GenericsSimple<T,TT> 我想要通过反射创建一个Demo.GenericsSimple<string,int>的实例可以通过下面的格式进行创建: System.Reflection.Assembly.GetExecutingAssembly().CreateInstance("命名空间.User`形参数量N[[1形参类型全名,形参类型所

  • C#反射应用实例

    本文实例讲述了C#反射应用.分享给大家供大家参考.具体如下: 通过反射实现多系统数据库的配置 通过定义接口,反射实例化配置的节点的值 配置App.config: 复制代码 代码如下: <?xml version="1.0" encoding="utf-8" ?> <configuration>   <appSettings>     <add key="DAL" value="FactoryIn

  • C#中的程序集和反射介绍

    什么是程序集? 1.程序集(assembly)是一个及一个以上托管模块,以及一些资源文件的逻辑组合. 2.程序集是组件复用,以及实施安全策略和版本策略的最小单位. 3.程序集是包含一个或者多个类型定义文件和资源文件的集合.在程序集包含的所有文件中,有一个文件用于保存清单.(清单是元数据部分中一组数据表的集合,其中包含了程序集中一部分文件的名称,描述了程序集的版本,语言文化,发布者,共有导出类型,以及组成该程序集的所有文件). 4.在编译应用程序中,所创建的CIL代码存储在一个程序集中,程序集包括

  • C#反射内存的处理分析

    本文实例分析了C#反射内存的处理.分享给大家供大家参考.具体分析如下: 这段时间由于公司的项目的要求,我利用c#的反射的机制做了一个客户端框架.客户端里的所有的模块都是以一定形式进行提供,例如:FORM,UserControl. 在做的过程中很简单与愉快.具体的过程如下: 1. 收集客户的需求 2. 整理需求,形成必要的文档 3. 通过讨论大体的得到程序的界面风格 4. 由UI设计师设计出来具体的界面形式 5. 通过需求封装必要的服务(我们可以使用c#的WCF服务或者JAVA的服务) 6. 制作

  • C#利用反射来判断对象是否包含某个属性的实现方法

    本文实例展示了C#利用反射来判断对象是否包含某个属性的实现方法,对于C#程序设计人员来说有一定的学习借鉴价值. 具体实现代码如下: /// <summary> /// 利用反射来判断对象是否包含某个属性 /// </summary> /// <param name="instance">object</param> /// <param name="propertyName">需要判断的属性</par

随机推荐