.net Reflection(反射)- 二

反射 Reflection 中访问方法

新建一个ClassLibrary类库:


    public class Student
{
public string Name
{ get; set; }
public string School
{ get; set; }

public int Sum(int a, int b)
{
return a + b;
}
public string GetName()
{
return "this is book" ;
}
}


    /// <summary>
/// 反射
/// </summary>
class Program
{

static void Main(string[] args)
{

Assembly assembly = Assembly.Load("ClassLibrary");
//调用 程序集 类的方法
//创建该对象的实例,object类型,参数(名称空间+类)
object instances = assembly.CreateInstance("ClassLibrary.Student");

//无参数 返回
object value = type.GetMethod("GetName").Invoke(instances, null);
       //返回this is book
//有参
object[] params_obj = new object[2];
params_obj[0] = 12;
params_obj[1] = 23;
object value1 = type.GetMethod("Sum").Invoke(instances, params_obj);
   //返回a b和
}

还可以通过 FindInterfaces 方法返回 接口信息

?





1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

//获取程序集接口 Stu 继承的所有接口

          Type t = typeof(Stu);

          Type[] interfaces = t.FindInterfaces(TypeFilter, assembly);

          //显示每个接口信息

          foreach
(Type i in
interfaces)

          {

              //获取映射接口方法的类型的方法

              InterfaceMapping mapping = t.GetInterfaceMap(i);

              for
(int
j = 0; j < mapping.InterfaceMethods.Length; j++)

              {

                  Console.WriteLine(" {0} 实现的 {1}", mapping.InterfaceMethods[j], mapping.TargetMethods[j]);

              }

          }

          

  

.net Reflection(反射)- 二

时间: 2024-10-12 20:53:52

.net Reflection(反射)- 二的相关文章

代替Reflection(反射)的一些方法

Reflection(反射)是深入学习.Net必须掌握的技能之一.最初学Reflection的时候,的确是被惊住了,原来还可以这样.只要给你一个Assembly, 你就能获取到其中所有的类型,根据类型,你能够创建和操作对象的属性和方法,甚至是私有的.但是,每次使用Reflection,看着那些丑陋难懂的代码,都让人不敢直视.下面就介绍一些在特定场景下可以替换Reflection的方法. 1. 使用Reflection完成的简单Demo 我们首先创建一个Person类,这个类非常简单,一个Name

入门反射(二)

原文:入门反射(二) 这篇来看一下反射的使用吧!举个例子! 举例子,肯定需要一个类啦,先建一个学生例子类: public class Student { public int Status; public int Id { get; set; } public string Name { get; set; } public string Sex { get; set; } public void Show() { Console.WriteLine("姓名:{0}", Name);

C#反射(二)

长时间没有回顾反射知识了,今天就讲解一下反射的一般第二个用法. 二.对方法,属性等的反射 首先需要写一个测试类,生成.exe或.dll文件. class Test {   public Test()//普通构造方法 {   } public string writeString(string s)//有参方法 {   return "welcome:" + s;  } public static string staticString(string s)//静态方法 {   retur

Java进阶之reflection(反射机制)——反射概念与基础

反射机制是Java动态性之一,而说到动态性首先得了解动态语言.那么何为动态语言? 一.动态语言 动态语言,是指程序在运行时可以改变其结构:新的函数可以引进,已有的函数可以被删除等结构上的变化.比如常见的JavaScript就是动态语言,除此之外Ruby,Python等也属于动态语言,而C.C++则不属于动态语言. 二.Java是动态语言吗? 从动态语言能在运行时改变程序结构结构或则变量类型上看,Java和C.C++一样都不属于动态语言. 但是JAVA却又一个非常突出的与动态相关的机制:反射机制.

C# 反射Reflection——反射反射程序员的快乐

一.什么是反射 反射Reflection:System.Reflection,是.Net Framework提供的一个帮助类库,可以读取并使用metadata. 反射是无处不在的,MVC-Asp.Net-ORM-IOC-AOP 几乎所有的框架都离不开反射 如下图是程序执行的过程,高级语言经过编译器编译得到dll/exe文件,这里的文件可以跨平台使用,编译后的文件中其实包括了metadata元数据(数据清单,描述了DLL/exe里面的各种信息)和IL(也是一种面向对象语言,但是不太好阅读)在经过C

Reflection(反射)

一.反射介绍 反射是.NET中的重要机制,通过反射,可以在运行时获得程序或程序集中每一个类型(包括类.结构.委托.接口和枚举等)的成员和成员的信息. 有了反射,即可对每一个类型了如指掌.另外我还可以直接创建对象,即使这个对象的类型在编译时还不知道. 二.反射的用途 1.使用Assembly定义和加载程序集,加载在程序集清单中列出模块,以及从此程序集中查找类型并创建该类型的实例 2.使用Module了解包含模块的程序集以及模块中的类等,还可以获取在模块上定义的所有全局方法或其他特定的非全局方法 3

C#反射(二) 【转】

如果没有看<C#反射(一)>.建议先看<C#反射(一)>再看这一篇.上一篇文章发表,有人评论我所写的东西比较基础.其实我也知道我也只不过是在写最基础的语法而已,之所以写它是因为自己学编程学了一两年之后才接触到反射,相信会有很多人跟我有过同样的经历.概其原因,书店里几乎90%的书籍都不谈反射.还有,曾经在百度.goole搜索过反射,但也很难找到自己喜欢的答案.希望我所写的东西能为那些初学编程的新手有所帮助. 我不想在这里过多的描述反射的概念.我还是用我自己觉得最简单.最直接的语言来描

Java Reflection(十二):动态类加载与重载

转载自并发编程网 – ifeve.com 内容索引类加载器类加载体系类加载动态类加载动态类重载自定义类重载类加载/重载示例Java允许你在运行期动态加载和重载类,但是这个功能并没有像人们希望的那么简单直接.这篇文章将阐述在Java中如何加载以及重载类.你可能会质疑为什么Java动态类加载特性是Java反射机制的一部分而不是Java核心平台的一部分.不管怎样,这篇文章被放到了Java反射系列里面而且也没有更好的系列来包含它了. 类加载器 所有Java应用中的类都是被java.lang.ClassL

.Net Reflection反射技术

这里写一下个人对.Net下反射技术的理解: 第一部分:个人讲讲反射 反射机制是一种运行时获取类(Type对象)和动态调用对象的成员的机制. a.可以获取有关已加载的程序集和在其中定义的类型(如类.接口和值类型)的成员信息: b.可以使用反射在运行时创建指定类的对象,以及调用和访问这些对象的成员. 这种动态获取的信息以及动态调用对象的方法的功能称为反射机制. 比如在myReflect.UI下定义了一个MyLyfeng类: public class MyLyfeng    {       //无参构

元数据与反射(二)

1.反射程序集 获取Assmbly对象有以下方法: (1)Assmbly.Load("程序集文件名称") Assembly assembly = Assembly.Load("类库Demo"); (2)Assmbly.LoadFrom("程序集文件名") Assembly assembly = Assembly.LoadFrom("类库Demo.dll"); 上述两个方法的区别就在于Load只需要提供文件名不加后缀的信息即可.