Object model=Assembly.Load(“程序集”).CreateInstance(命名空间.类名);

object obj2 = Type.GetType("MyClass").GetMethod("Add").Invoke(obj,null);

obj2是返回值

Activator.CreateInstance会调用dll中类的构造函数,如果你的类里面没有提供无参的构造函数

Assembly _Assembly = Assembly.Load("程序集名");
Type _Type = _Assembly.GetType("完整类名");
Form _Form = (Form)Activator.CreateInstance(_Type);
System.Reflection.EventInfo _EventInfo = _Type.GetEvent("RemoveFormHandler");

_EventInfo.AddEventHandler(_Form, new Com.Psi.UIBase.RemoveFormDelegate(RemoveForm));

System.Reflection.FieldInfo _FieldInfoSys = _Type.GetField("m_SysDataSet");
_FieldInfoSys.SetValue(_Form, this.m_TableDataSet);

_Form.Show()

//创建对象
            ////Assembly assembly = Assembly.LoadFile();
            //Assembly assembly = Assembly.Load("Test2");
           
//Object obj1 = assembly.CreateInstance("Test2.Reflect.Operate",
false);//assembly.CreateInstance内部调用Activator.CreateInstance
           
//Object obj2 = assembly.CreateInstance("Test2.Reflect.Operate", false,
BindingFlags.Default, Type.DefaultBinder, new Object[] { "123" },
System.Globalization.CultureInfo.CurrentCulture, new Object[] { });

//Object obj3 = Activator.CreateInstance(Type.GetType("Test2.Reflect.Operate"));
            //Object obj4 = Activator.CreateInstance(Type.GetType("Test2.Reflect.Operate"),"456");

//Type type = Type.GetType("Test2.Reflect.Operate");
            ////每次调用InvokeMemeber方法时,它必须先绑定到一个特定的成员,然后才能调用它。
            ////如果每次调用一个成员时都让绑定器选择适当的成员,那么将是非常耗时的。。建议用:一次绑定,多次调用
            //Object obj5 = type.InvokeMember("Operate", BindingFlags.CreateInstance, null, null, new Object[] { "789" });
            
            //Assembly assembly = Assembly.Load("Test2");
            //Type t = assembly.GetType("Test2.Reflect.Operate");
            //ConstructorInfo constructorInfo = t.GetConstructor(new Type[] { typeof(string) });
            //Object obj6 = constructorInfo.Invoke(new Object[] { "kkkkkkkk" });

//AppDomain appDomain = AppDomain.CurrentDomain;  //内部也是调用的Activator.CreateInstance
            //ObjectHandle objHandle = appDomain.CreateInstance("Test2", "Test2.Reflect.Operate");
            //Object obj7 = objHandle.Unwrap();

//除了数组和委托之外,其他都可以利用上述通过反射创建对象

//访问变量
            //Assembly assembly = Assembly.Load("Test2");
            //Object obj1 = assembly.CreateInstance("Test2.Reflect.Operate", false);
            //Type type = Type.GetType("Test2.Reflect.Operate");
           
//FieldInfo fieldInfo = type.GetField("_Address");  //获取私有字段 
("_Address",BindingFlags.NoPublic|bindingFlags.instance)
            //Object ret= fieldInfo.GetValue(obj1);

     //私有静态字段,BindingFlags的次序必须一致。FieldInfo fieldInfo = type.GetField("_instance", BindingFlags.Static | BindingFlags.NonPublic);

//属性
            //Assembly assembly = Assembly.Load("Test2");
            //Object obj1 = assembly.CreateInstance("Test2.Reflect.Operate", false);
            //Type type = Type.GetType("Test2.Reflect.Operate");
            //PropertyInfo propertyInfo = type.GetProperty("Val");
            //propertyInfo.SetValue(obj1, 1, null); //为属性赋值
            //Object ret = propertyInfo.GetValue(obj1, null);//获取属性的值

//索引器
            //Assembly assembly = Assembly.Load("Test2");
            //Object obj1 = assembly.CreateInstance("Test2.Reflect.Operate", false);
            //Type type = Type.GetType("Test2.Reflect.Operate");
            //PropertyInfo propertyInfo = type.GetProperty("Item");
            //Object ret = propertyInfo.GetValue(obj1,new Object[]{2});   //获取索引器的值
            //propertyInfo.SetValue(obj1, 1,new Object[]{6});             //为索引器赋值
            //ret = propertyInfo.GetValue(obj1, new Object[] { 6 });      //获取索引器的值

//访问静态方法
            //Assembly assembly = Assembly.Load("Test2");
            //Type t = assembly.GetType("Test2.Reflect.Operate");
            //MethodInfo met = t.GetMethod("ExcStaticMethod", new Type[] { typeof(string) });
            //Object ret = met.Invoke(null, new Object[] { "参数" });

//Type t = Type.GetType("Test2.Reflect.Operate");//如果在同一个项目中或已经添加引用
            //MethodInfo met = t.GetMethod("ExcStaticMethod", new Type[] { typeof(string) });
            //Object ret = met.Invoke(null, new Object[] { "传递的参数" });
          
            //访问方法
            //Assembly assembly = Assembly.Load("Test2");
            //Object obj1 = assembly.CreateInstance("Test2.Reflect.Operate", false);
            //Type t = assembly.GetType("Test2.Reflect.Operate");
            //MethodInfo met = t.GetMethod("ExcMethod", new Type[] {typeof(string) });
            //Object ret = met.Invoke(obj1, new Object[] {"参数" });

//事件
            //Assembly assemblytemp = Assembly.Load("Test2");
            //Object objtemp = assemblytemp.CreateInstance("Test2.Reflect.Operate", false);
            //Type te = Type.GetType("Test2.Reflect.Operate");
            //EventInfo evnetInfo = te.GetEvent("hander");
            ////EventHandler eh = new EventHandler(delegate(Object obj,EventArgs e) { Console.WriteLine("LLLLLLL"); });
            //EventHandler eh = new EventHandler(delegate { Console.WriteLine("LLLLLLL"); });
            //evnetInfo.AddEventHandler(objtemp, eh);
            //MethodInfo met = te.GetMethod("ExcEvent", new Type[] { });
            //Object ret = met.Invoke(objtemp, new Object[] {  });

C#反射代码的更多相关文章

  1. C#高级编程 反射 代码示例

    反射 反射(Reflection)是.NET中的重要机制,通过反射,可以在运行时获得.NET中每一个类型(包括类.结构.委托.接口和枚举等)的成员,包括方法.属性.事件,以及构造函数等. 还可以获得每 ...

  2. Java之反射代码演示说明

    还不存在的类–即我们需要使用反射来使用的类 Person类: package com.qf.demo4; public class Person { private String name; publ ...

  3. 使用spring提供的ReflectionUtils简化项目中反射代码的复杂性

    在项目中有时候我们会使用到反射的功能,如果使用最原始的方法来开发反射的功能的话肯能会比较复杂,需要处理一大堆异常以及访问权限等问题.spring中提供了ReflectionUtils 这个反射的工具类 ...

  4. C#-逆变 协变 反射 代码

    首先看一段测试代码,自己写的 class Program { static void Main(string[] args) { man OneMan = new man(); var d = One ...

  5. 利用注解进行sql反射代码示例

    @Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) public @interface Table { String val ...

  6. 编写高质量代码改善C#程序的157个建议——建议15: 使用dynamic来简化反射实现

    建议15: 使用dynamic来简化反射实现 dynamic是Framework 4.0的新特性.dynamic的出现让C#具有了弱语言类型的特性.编译器在编译的时候不再对类型进行检查,编译器默认dy ...

  7. 编写高质量代码:改善Java程序的建议

    建议的采用顺序是List<T>.List<?>.List<Object> List<T>.List<?>.List<Object> ...

  8. ClownFish:比手写代码还快的通用数据访问层

    http://www.cnblogs.com/fish-li/archive/2012/07/17/ClownFish.html 阅读目录 开始 ClownFish是什么? 比手写代码还快的执行速度 ...

  9. java中复制对象通过反射或序列化

    在使用缓存读取数据后修改发现缓存被修改.于是找了下复制对象的方法. 关于对象克隆 按我的理解,对象是包含引用+数据.通常变量复制都是将引用传递过去.比如: Person p1 = new Person ...

随机推荐

  1. SVN组成中trunk,branches and tags功能用法详解

    SVN组成中trunk,branches and tags功能用法详解  我相信初学开发在SVN作为版本管理时,都估计没可能考虑到如何灵活的运用SVN来管理开发代码的版本,下面我就摘录一篇文章来简单说 ...

  2. python 操作mysql

    安装模块: #pip install .... MySQLdb(2.x) pymysql(3.x) import MySQLdb as sql con = sql.connect( host = &q ...

  3. lightning mdb 源代码分析(4)—MVCC/COW

    本博文将描述MVCC和cow技术以及LMDB中如何使用以及实现这两种技术. COW(Copy On Write): COW技术背后的思想是拖延技术,基本方法是假如有多个调用者需要访问的资源,在其初始化 ...

  4. lightning mdb 源代码分析系列(3)

    本系列前两章已经描述了系统架构以及系统构建的基础内存映射,本章将详细描述lmdb的核心,外存B+Tree的操作.本文将从基本原理.内存操作方式.外存操作方式以及LMDB中的相关函数等几方面描述LMDB ...

  5. JS - 超强大文本动画插件Textillate.js

    http://www.yyyweb.com/demo/textillate/ Textillate.js AsimplepluginforCSS3textanimations.

  6. [转]Session服务器配置指南与使用经验

    本文转自:http://www.cnblogs.com/zhangziqiu/archive/2009/03/26/SessionServer.html 一.摘要 所有Web程序都会使用Session ...

  7. [转]如何:定义和处理 SOAP 标头

    本文转自:http://msdn.microsoft.com/zh-cn/library/vstudio/8728chd5(v=vs.100).aspx 本主题专门介绍一项旧有技术.现在应通过使用以下 ...

  8. 1215课后练习----indexOf的用法

    package com.hanqi; public class Testco { public static void main(String[] args) { String str1 = &quo ...

  9. [转自51CTO]ITIL与ISO20000的关系

    ITIL它不是一个服务管理标准,而更应该说是一种结构化的方法或流程框架.基于这种方法和框架,已经有越来越多的IT服务管理标准被开发出来了.在这些基于ITIL的IT服务管理标准中,最突出的要属英国标准B ...

  10. 【液晶模块系列基础视频】3.1.fatfs文件系统的移植及接口函数的使用

    ============================== 技术论坛:http://www.eeschool.org 博客地址:http://xiaomagee.cnblogs.com 官方网店:h ...