博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# 反射(转)
阅读量:5301 次
发布时间:2019-06-14

本文共 3488 字,大约阅读时间需要 11 分钟。

什么是反射

        Reflection,中文翻译为反射。

        这是.Net中获取运行时类型信息的方式,.Net的应用程序由几个部分:‘程序集(Assembly)’、‘模块(Module)’、‘类型 (class)’组成,而反射提供一种编程的方式,让程序员可以在程序运行期获得这几个组成部分的相关信息,例如:

        Assembly类可以获得正在运行的装配件信息,也可以动态的加载装配件,以及在装配件中查找类型信息,并创建该类型的实例。

Type类可以获得对象的类型信息,此信息包含对象的所有要素:方法、构造器、属性等等,通过Type类可以得到这些要素的信息,并且调用之。
MethodInfo包含方法的信息,通过这个类可以得到方法的名称、参数、返回值等,并且可以调用之。
诸如此类,还有FieldInfo、EventInfo等等,这些类都包含在System.Reflection命名空间下。

2、命名空间与装配件的关系

        很多人对这个概念可能还是很不清晰,对于合格的.Net程序员,有必要对这点进行澄清。
        命名空间类似与Java的包,但又不完全等同,因为Java的包必须按照目录结构来放置,命名空间则不需要。

        装配件是.Net应用程序执行的最小单位,编译出来的.dll、.exe都是装配件。

        装配件和命名空间的关系不是一一对应,也不互相包含,一个装配件里面可以有多个命名空间,一个命名空间也可以在多个装配件中存在,这样说可能有点模糊,举个例子:
首先我们建立一个类库,将它生成为HelloWorld.dll,
using System;
 namespace Webtest
 ...{
    public interface interface1
     ...{
          int add();
     
     }
     public class ReflectTest:interface1
     ...{
         
         public String Write;
         private String Writec;
         public String Writea
         ...{
             get
             ...{
                 return Write;
             }
             set
             ...{
                 Write = value;
             }
         
         }
         private String Writeb
         ...{
             get
             ...{
                 return Writec;
             }
             set
             ...{
                 Writec = value;
             }
         }
          public ReflectTest()
          ...{
              this.Write = "Write";
              this.Writec = "Writec";
          }
         public ReflectTest(string str1,string str2)
         ...{
             this.Write = str1;
             this.Writec = str2;
         }
         public string WriteString(string s,int b)
         ...{
             return "欢迎您," + s + "---" + b; ;
         }
          public static string WriteName(string s)
          ...{
             return "欢迎您光临," + s;
          }
         public string WriteNoPara()
         ...{
            return "您使用的是无参数方法";
         }
         private string WritePrivate()
         ...{
             return "私有类型的方法";
         }
         public int add()
         ...{
             return 5;
         }
     }
}
然后,建立再建立一个项目引入该HelloWorld.dll,
using System;
using System.Threading;
using System.Reflection;
class Test
...{
    delegate string TestDelegate(string value,int value1);
   static void Main()
    ...{
        //Assembly t = Assembly.LoadFrom("HelloWorld.dll"); 与下面相同的效果
        Assembly t = Assembly.Load("HelloWorld");
//**********************************************************************     
       foreach (Type aaa in t.GetTypes())
       ...{
            //Console.Write(aaa.Name);   //显示该dll下所有的类
        }
//**********************************************************************
        Module[] modules = t.GetModules();
        foreach (Module module in modules)
        ...{
            //Console.WriteLine("module name:" + module.Name);//显示模块的名字本例为"HelloWorld.dll"
        }
//**********************************************************************
        Type a = typeof(Webtest.ReflectTest);//得到具体的类的类型,和下面一个效果
        //Type a = t.GetType("Webtest.ReflectTest");//
        //Console.Write(a.Name);
//**********************************************************************
        string[] bb =..."aaaa""bbbbb" };
        object obj = Activator.CreateInstance(a,bb); //创建该类的实例,后面的bb为有参构造函数的参数
        //object obj = t.CreateInstance("Webtest.ReflectTest");//与上面方法相同
//**********************************************************************        
        MethodInfo[] miArr = a.GetMethods();
        foreach (MethodInfo mi0 in miArr)
       ...{
            //Console.Write(mi0.Name);  //显示所有的共有方法
       }
//**********************************************************************
        MethodInfo mi = a.GetMethod("WriteString");//显示具体的方法
        object[] aa=...{
"使用的是带有参数的非静态方法",2};
        string s = (string)mi.Invoke(obj,aa); //带参数方法的调用
        MethodInfo mi1 = a.GetMethod("WriteName");
        String[] aa1 =...{
"使用的是静态方法"};
        string s1 = (string)mi1.Invoke(null, aa1); //静态方法的调用
        MethodInfo mi2 = a.GetMethod("WriteNoPara");
        string s2 = (string)mi2.Invoke(obj, null); //不带参数的方法调用
        MethodInfo mi3 = a.GetMethod("WritePrivate",BindingFlags.Instance | BindingFlags.NonPublic);
        string s3 = (string)mi3.Invoke(obj, null); //私有类型方法调用
        //Console.Write(s3);
//**********************************************************************

转载于:https://www.cnblogs.com/xz4062006/p/4245565.html

你可能感兴趣的文章
shell编程报错 [: missing `]'
查看>>
python 基础(四) 函数
查看>>
互联网的总体构思(二)
查看>>
Hibernate Annotation (Hibernate 注解)
查看>>
solrCloud 管理
查看>>
tomcat源码导入eclipse
查看>>
PEM文件格式详细解析
查看>>
Opc
查看>>
威信公众助手
查看>>
10.2图片处理
查看>>
高性能服务器本质论
查看>>
从小白角度探索Android事件分发机制
查看>>
23种设计模式--建造者模式-Builder Pattern
查看>>
十. 图形界面(GUI)设计13.鼠标事件
查看>>
webform简单、复合控件
查看>>
Java IO(二)--RandomAccessFile基本使用
查看>>
iOS 企业证书发布app 流程
查看>>
if和for的几个经典题目
查看>>
英语单词分类(待补充)
查看>>
POJ3087Shuffle'm Up(map)
查看>>