C#反射代码
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#反射代码的更多相关文章
- C#高级编程 反射 代码示例
反射 反射(Reflection)是.NET中的重要机制,通过反射,可以在运行时获得.NET中每一个类型(包括类.结构.委托.接口和枚举等)的成员,包括方法.属性.事件,以及构造函数等. 还可以获得每 ...
- Java之反射代码演示说明
还不存在的类–即我们需要使用反射来使用的类 Person类: package com.qf.demo4; public class Person { private String name; publ ...
- 使用spring提供的ReflectionUtils简化项目中反射代码的复杂性
在项目中有时候我们会使用到反射的功能,如果使用最原始的方法来开发反射的功能的话肯能会比较复杂,需要处理一大堆异常以及访问权限等问题.spring中提供了ReflectionUtils 这个反射的工具类 ...
- C#-逆变 协变 反射 代码
首先看一段测试代码,自己写的 class Program { static void Main(string[] args) { man OneMan = new man(); var d = One ...
- 利用注解进行sql反射代码示例
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) public @interface Table { String val ...
- 编写高质量代码改善C#程序的157个建议——建议15: 使用dynamic来简化反射实现
建议15: 使用dynamic来简化反射实现 dynamic是Framework 4.0的新特性.dynamic的出现让C#具有了弱语言类型的特性.编译器在编译的时候不再对类型进行检查,编译器默认dy ...
- 编写高质量代码:改善Java程序的建议
建议的采用顺序是List<T>.List<?>.List<Object> List<T>.List<?>.List<Object> ...
- ClownFish:比手写代码还快的通用数据访问层
http://www.cnblogs.com/fish-li/archive/2012/07/17/ClownFish.html 阅读目录 开始 ClownFish是什么? 比手写代码还快的执行速度 ...
- java中复制对象通过反射或序列化
在使用缓存读取数据后修改发现缓存被修改.于是找了下复制对象的方法. 关于对象克隆 按我的理解,对象是包含引用+数据.通常变量复制都是将引用传递过去.比如: Person p1 = new Person ...
随机推荐
- CKEditor实现图片上传
本人用的CKEditor版本为4.3 CKEditor配置和部署参考CKEditor4.x部署和配置. CKEditor编辑器的工具栏中初始的时候应该是这样子的,没有图片上传按钮 并且预览中有一堆火星 ...
- 深度解析开发项目之 05 - 解决textField编辑之后点击其他内容改变的问题
深度解析开发项目之 05 - 解决textField编辑之后点击其他内容改变的问题 问题的解决: 只需要给HeadeVIew加上这句代码
- shell总结(0基础入门)
一.简介 shell是用户和操作系统交互的命令行解释器. shell有很多种: bash.csh.sh.ksh... 我们等了linux时看到的命令行就是一个bash. 二.第一个脚本: [root@ ...
- mysql主从配置脚本
PASSWD=123456USER=rootREP_HOST=10.10.10.70REP_PORT=3306REP_USER=slaveREP_PASSWD=123456@REP_FILE=mysq ...
- lightning mdb 源代码分析(2)
本系列前一篇已经分析了lightningmdb的整体架构和主要的数据结构.本文将介绍一下MMAP原理以及lmdb中如何使用它. 1. Memory Map原理 内存映射文件与虚拟内存有些类似,通过内存 ...
- Redis Cluster 3.0搭建与使用
Redis Cluster终于出了Stable,这让人很是激动,等Stable很久了,所以还是先玩玩. 一. 集群简单概念. Redis 集群是一个可以在多个 Redis 节点之间进行数据共享的设施( ...
- zhcon安装过程记录
参考资料: 1. http://www.linuxdiyf.com/viewarticle.php?id=81796 需要下载的文件有两个:zhcon-0.2.5.tar.gz和zhcon-0.2.5 ...
- 禁止用户自己停止SEP - 飞舞的菜刀 - 51CTO技术博客
员工在自己的工作站上,右键点击状态栏SEP图标,停止SEP服务,导致管理员定制的策略失效,针对上述情况,请安装下述方法操作. 1. 打开SEPM. 2. 在[策略]里选中你所使用的[防病毒和防间谍软件 ...
- nodejs:本地文件夹http服务器http-server
一.已经安装nodejs的电脑,有一个方便通过http访问本地文件夹.文件夹服务器 static files over HTTP,并不是我们平常说的node那个web服务器哦 二.好处 可以方便实现跨 ...
- 如何查询MySql日志
如何查询MySql日志 分类: mysql2012-02-23 19:14 26756人阅读 评论(2) 收藏 举报 mysqlcommandprintingserversocketoutput 今天 ...