今天把反射的东西整理了一下 , 提供了最全面的东西 , 当然也是基础的东西 ,
在学好了这一切的基础上 , 大家可以学习反射的具体插件等应用 首先我们建立一个类库 , 将它生成为 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#反射之基础应用的更多相关文章

  1. java Reflection(反射)基础知识讲解

    原文链接:小ben马的java Reflection(反射)基础知识讲解 1.获取Class对象的方式 1.1)使用 "Class#forName" public static C ...

  2. java反射机制(基础版)

    package com.reflect; import java.lang.reflect.Constructor; import java.lang.reflect.Field; import ja ...

  3. JAVA反射机制基础概念

    反射机制:所谓的反射机制就是java语言在运行时拥有一项自观的能力.通过这种能力可以彻底的了解自身的情况为下一步的动作做准备.下面具体介绍一下java的反射机制.这里你将颠覆原来对java的理解. J ...

  4. java反射的基础学习代码

    java反射的学习,好多东西不太理解,主要分析了constructor,method,field,数组和调用main函数等反射的多个方面小例子. 主要的练习类 package javaAdvanced ...

  5. 透彻分析反射的基础_Class类

    一.反射的基石--->Class类 1. Java类用于描述一类事物的特性,该类事物有什么属性,没有什么属性,值域这个属性的值是什么,则是由这个类的实例对象来确定的,不同的实例对象有不同的属性值 ...

  6. C# 反射_基础

    反射用于在程序运行过程中,获取类里面的信息或发现程序集并运行的一个过程.通过反射可以获得.dll和.exe后缀的程序集里面的信息.使用反射可以看到一个程序集内部的类,接口,字段,属性,方法,特性等信息 ...

  7. Java基础---基础加强---增强for循环、自动拆装箱及享元、枚举的作用、实现带有构造方法、透彻分析反射的基础_Class类、成员变量的反射、数组参数的成员方法进行反射、数组的反射应用

    在perference 加content Assist 可以设置快捷键 透视图与视图 透视图:Debug和java主窗口 视图:每一个小窗口就是视图 高版本的java可运行低版本的java版本 常见的 ...

  8. 反射那些基础-Class

    目录 1 Class 类是什么? 2 如何获取 Class 对象 2.1 Object.getClass() 2.2 .class 语法 2.3 Class.forName() 2.4 通过包装类的 ...

  9. Java反射之基础概念

    0.实例准备 package com.blueStarWei.invoke; public class Student { private String name; public Student() ...

随机推荐

  1. 转载---SQL Server XML基础学习<1>之--FOR XML PATH

    --> 测试数据:#tbIF OBJECT_ID('TEMPDB.DBO.#tb') IS NOT NULL    DROP TABLE #tbGO CREATE TABLE #tb      ...

  2. asp.net中Get请求和Post请求

    Get和Post请求的区别:Get请求因为传输的数据在URL中,因此不安全,而且多数浏览器有限制其长度,最长为2KB.通过Get请求获取数据的方式:string strName=context.Req ...

  3. sql的临时表使用小结

    1.创建方法: 方法一:create table TempTableName或select [字段1,字段2,...,] into TempTableName from table 方法二:creat ...

  4. iOS 动画基础

    原文:http://www.cnblogs.com/lujianwenance/p/5733846.html   今天说一下有关动画的基础,希望能帮助到一些刚接触iOS动画或者刚开始学习iOS的同学, ...

  5. 如何在Angular2中使用jquery

    首先在index.html中引入jquery文件 <script src="http://cdn.bootcss.com/jquery/2.1.3/jquery.js"> ...

  6. UVA 11991 Easy Problem from Rujia Liu?(vector map)

    Easy Problem from Rujia Liu? Though Rujia Liu usually sets hard problems for contests (for example, ...

  7. 命令行下上传文件到iOS软件 专业文件管理/gplayer

    U盘丢了, 就拿手机当U盘用用先. 一般情况下软件打开上传功能, 在浏览器里上传即可. 可是偏偏我的电影放在了 树莓派里面(搭建了一个SMB), 直接浏览器的话,会多占用些带宽, 我的破路由器.... ...

  8. 专题二、ArrayList序列化技术细节详解

    一.绪论 所谓的JAVA序列化与反序列化,序列化就是将JAVA 对象以一种的形式保持,比如存放到硬盘,或是用于传输.反序列化是序列化的一个逆过程. JAVA规定被序列化的对象必须实现java.io.S ...

  9. Linux下U盘的格式化

    一次系统装机带来的烦恼. 之前有一次装centos 系统 ,把一个centos4.8的系统刻录到了一个8G的U盘,之后是centos安装成功了 ,却发现电脑不认识U盘了,试了好多次也没有处理好,刚好今 ...

  10. x264_param_t结构

    typedef struct x264_param_t { unsigned int cpu; // CPU 标志位 int i_threads; // 并行编码多帧; 线程数,为0则自动多线程编码 ...