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. iOS-TextField知多少

    iOS-TextField知多少 //初始化textfield并设置位置及大小 UITextField *text = [[UITextField alloc]initWithFrame:CGRect ...

  2. Redhat系列Linux的基础命令

    为网卡配置静态IP地址vi /etc/sysconfig/network-scripts/ifcfg-eth0DEVICE=eth0ONBOOT=yesBOOTPROTO=staticHWADDR=0 ...

  3. OpenCV学习笔记——多种Smooth平滑处理

    opencv库提供了好几种模糊平滑Smooth操作的类型作为cvSmooth的参数传入,从而达到不同的平滑效果,另外复习了一下如何复制一份图像和重新调整图像大小. 调整图像大小目前是按照一下步骤进行: ...

  4. Nginx 笔记与总结(10)Nginx 与 PHP 整合

    Apache + PHP 的编译 和 Nginx + PHP 的编译,区别: Apache 一般把 PHP 当作自己的一个模块来启动: Nginx 则是把 HTTP 请求变量(如 get,user_a ...

  5. Linux 执行ThinkPHP 文件的计划任务

    执行例如 http://192.168.1.32/index.php?s=/Home/Cron/yue 这样的 url 的计划任务 方式① */ * * * * curl http://192.168 ...

  6. 龙珠 超宇宙 [Dragon Ball Xenoverse]

    保持了动画气氛实现的新时代的龙珠视觉 今年迎来了[龙珠]系列的30周年,为了把他的魅力最大限度的发挥出来的本作的概念,用最新的技术作出了[2015年版的崭新的龙珠视觉] 在沿袭了一直以来优秀的动画世界 ...

  7. nginx日志配置[转]

     * * * sh /home/zyf/sh/cut_nginx_log.sh 这样就每天的0点1分把nginx日志重命名为日期格式,并重新生成今天的新日志文件。 日志对于统计排错来说非常有利的。本文 ...

  8. 区分super和this

    Java关键字this.super使用总结 一.this Java关键字this只能用于方法方法体内.当一个对象创建后,Java虚拟机(JVM)就会给这个对象分配一个引用自身的指针,这个指针的名字就是 ...

  9. 大话数据结构(十二)java程序——KMP算法及改进的KMP算法实现

    1.朴素的模式匹配算法 朴素的模式匹配算法:就是对主串的每个字符作为子串开头,与要连接的字符串进行匹配.对主串做大循环,每个字符开头做T的长度的小循环,直到成功匹配或全部遍历完成为止. 又称BF算法 ...

  10. prior knowledge

    https://en.wikipedia.org/wiki/Bayes'_theorem For example, if cancer is related to age, then, using B ...