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#反射之基础应用的更多相关文章
- java Reflection(反射)基础知识讲解
原文链接:小ben马的java Reflection(反射)基础知识讲解 1.获取Class对象的方式 1.1)使用 "Class#forName" public static C ...
- java反射机制(基础版)
package com.reflect; import java.lang.reflect.Constructor; import java.lang.reflect.Field; import ja ...
- JAVA反射机制基础概念
反射机制:所谓的反射机制就是java语言在运行时拥有一项自观的能力.通过这种能力可以彻底的了解自身的情况为下一步的动作做准备.下面具体介绍一下java的反射机制.这里你将颠覆原来对java的理解. J ...
- java反射的基础学习代码
java反射的学习,好多东西不太理解,主要分析了constructor,method,field,数组和调用main函数等反射的多个方面小例子. 主要的练习类 package javaAdvanced ...
- 透彻分析反射的基础_Class类
一.反射的基石--->Class类 1. Java类用于描述一类事物的特性,该类事物有什么属性,没有什么属性,值域这个属性的值是什么,则是由这个类的实例对象来确定的,不同的实例对象有不同的属性值 ...
- C# 反射_基础
反射用于在程序运行过程中,获取类里面的信息或发现程序集并运行的一个过程.通过反射可以获得.dll和.exe后缀的程序集里面的信息.使用反射可以看到一个程序集内部的类,接口,字段,属性,方法,特性等信息 ...
- Java基础---基础加强---增强for循环、自动拆装箱及享元、枚举的作用、实现带有构造方法、透彻分析反射的基础_Class类、成员变量的反射、数组参数的成员方法进行反射、数组的反射应用
在perference 加content Assist 可以设置快捷键 透视图与视图 透视图:Debug和java主窗口 视图:每一个小窗口就是视图 高版本的java可运行低版本的java版本 常见的 ...
- 反射那些基础-Class
目录 1 Class 类是什么? 2 如何获取 Class 对象 2.1 Object.getClass() 2.2 .class 语法 2.3 Class.forName() 2.4 通过包装类的 ...
- Java反射之基础概念
0.实例准备 package com.blueStarWei.invoke; public class Student { private String name; public Student() ...
随机推荐
- 第三篇:gradle 编译 Android app 概览
引言:经过上两篇的论述,我们已经从代码到架构都简单的熟悉了一遍,理论上,只要知道android app的编译过程,我们大可以自己写一份用gradle编译app的插件,插件内将将整个流程用Task的依赖 ...
- row_number() OVER (PARTITION BY COL1 ORDER BY COL2)
select *,ROW_NUMBER() over(partition by deviceID order by RecordDate desc row_number() OVER (PARTITI ...
- 零基础Visual Fox Pro 6.0自学笔记(VFP6.0图文教程)
序:有个哥们读大一,学的金融,由于考试需要去学VFP.拜托我帮忙找教程,发觉网上没有合适的,教学视频多半要收费,优秀文档很少.微软官方也不重视VFP了,真可惜.遂生出写一个入门教程的想法.图文并茂的可 ...
- phaser源码解析(二) Phaser.Utils类下pad方法
/** *#填充字符串方法 * Javascript string pad http://www.webtoolkit.info/. * pad = the string to pad it out ...
- Javascript模仿C语言的链表实现(增删改查),并且使用控制台输入输出
Js新手最近在研究Js数据结构,刚好看到链表实现这一块儿,觉得有些资料和自己理解的有冲突,于是借着自己以前一点点C语言的基础,用Javascript模仿了C的链表实现,并且用了process.stdi ...
- android studio安装后卡在fetching Android sdk compoment information
解决办法: 找到android studio 安装目录下bin目录中(D:\Android\Android Studio\bin)的idea.properties文件,在文件末尾处添加disable. ...
- Java内存模型JMM与可见性
Java内存模型JMM与可见性 标签(空格分隔): java 1 何为JMM JMM:通俗地讲,就是描述Java中各种变量(线程共享变量)的访问规则,以及在JVM中将变量存储到内存和从内存中读取变量这 ...
- 理解Java中的前期绑定和后期绑定
前期绑定,在程序执行前根据编译时类型绑定,调用开销较小,如C语言只有前期绑定这种方法调用. 后期绑定,是指在运行时根据对象的类型进行绑定,又叫动态绑定或运行时绑定.实现后期绑定,需要某种机制支持,以便 ...
- centOS 6.4 vsftpd 500 illegal port command
原先配置好的vsftpd突然不行了,不知为啥,感觉跟网络有关,这个网络总是有dns拦截的现象,..小公司.真烦人,用联通线路就没问题, 但同事就是连不上,我的笔记本却可以连接上..我的ubuntn,同 ...
- svn强制添加注释脚本
@echo off setlocal set SVN_BINDIR=C:/Program Files/VisualSVN Server/bin/ set REPOS=%1 set TXN=%2 rem ...