博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
c# 反射
阅读量:6155 次
发布时间:2019-06-21

本文共 3214 字,大约阅读时间需要 10 分钟。

反射的用途:
    (1)使用Assembly定义和加载程序集,加载在程序集清单中列出模块,以及从此程序集中查找类型并创建该类型的实例。 
    (2)使用Module了解包含模块的程序集以及模块中的类等,还可以获取在模块上定义的所有全局方法或其他特定的非全局方法。 
    (3)使用ConstructorInfo了解构造函数的名称、参数、访问修饰符(如pulic 或private)和实现详细信息(如abstract或virtual)等。 
    (4)使用MethodInfo了解方法的名称、返回类型、参数、访问修饰符(如pulic 或private)和实现详细信息(如abstract或virtual)等。
    (5)使用FiedInfo了解字段的名称、访问修饰符(如public或private)和实现详细信息(如static)等,并获取或设置字段值。
    (6)使用EventInfo了解事件的名称、事件处理程序数据类型、自定义属性、声明类型和反射类型等,添加或移除事件处理程序。 
    (7)使用PropertyInfo了解属性的名称、数据类型、声明类型、反射类型和只读或可写状态等,获取或设置属性值。 
    (8)使用ParameterInfo了解参数的名称、数据类型、是输入参数还是输出参数,以及参数在方法签名中的位置等。
图片
上图为群中一大神写得demo
我在项目中用到的方法如下
/// <summary>
        /// 得到模拟故障方法
        /// </summary>
        /// <param name="className"></param>
        public void GetFaultFun(string className)
        {
            var assembly = Assembly.Load("FaultDll").CreateInstance(className, true);
            var methods = assembly.GetType().GetMethods();
            methodlist.Clear();
            foreach (MethodInfo m in methods)
            {
                if (m.Name != "ToString" && m.Name != "GetHashCode" && m.Name != "GetType" && m.Name != "Equals" && m.IsPublic)
                {
                    System.Windows.Controls.RadioButton radio = new System.Windows.Controls.RadioButton();
                    radio.Name = m.Name;
                    radio.Content = m.Name;
                    radio.IsChecked = false;
                    radio.Click += radio_Click;
                    radio.Margin = new Thickness(10, 5, 0, 0);
                    this.function.Children.Add(radio);
                    methodlist.Add(m);
                }
            }
        }
/// <summary>
        /// 得到方法参数
        /// </summary>
        /// <param name="funName"></param>
        public void GetParameters(string funName)
        {
            foreach (MethodInfo m in methodlist)
            {
                if (m.Name == funName)
                {
                    for (int i = 8; i < m.GetParameters().Count(); i++)
                    {
                        var p = m.GetParameters()[i];
                        StackPanel panel = new StackPanel();
                        panel.Name = p.Name;
                        panel.Orientation = System.Windows.Controls.Orientation.Horizontal;
                        panel.Margin = new Thickness(10, 5, 0, 0);
                        TextBlock tb = new TextBlock();
                        tb.Margin = new Thickness(10, 0, 0, 0);
                        tb.Text = p.Name + ":";
                        System.Windows.Controls.TextBox tbx = new System.Windows.Controls.TextBox();
                        tbx.Width = 40;
                        tbx.Margin = new Thickness(10, 0, 0, 0);
                        panel.Children.Add(tb);
                        panel.Children.Add(tbx);
                        this.parameters.Children.Add(panel);
                    }
                }
            }
        }
/// <summary>
        /// 调用dll函数
        /// </summary>
        /// <param name="fun"></param>
        public void InvokeFunc(string fun)
        {
            try
            {
                ArrayList list = GetParamsArray();
                Type[] types = Assembly.Load("FaultDll").GetTypes();//LoadFile
                foreach (Type t in types)
                {
                    MethodInfo m = t.GetMethod(fun);
                    if (m != null)
                    {
                        object o = Activator.CreateInstance(t);
                        object[] invokeArgs = new Object[] { resultmapA, resultmapB,bytedatas, startPositionA, endPositionA, startPositionB, endPositionB,list,null,null };
                        m.Invoke(o, invokeArgs);
                        resultmapA = invokeArgs[0] as Bitmap;//ref参数
                        resultmapB = invokeArgs[1] as Bitmap;
                        bytedatas = invokeArgs[2] as byte[];
                    }
                }
            }
            catch (Exception ex)
            {
                System.Windows.MessageBox.Show(ex.Message);
            }
        }
 
反射用到的主要类:
    System.Type 类--通过这个类可以访问任何给定数据类型的信息。
    System.Reflection.Assembly类--它可以用于访问给定程序集的信息,或者把这个程序集加载到程序中。
System.Type类:
    System.Type 类对于反射起着核心的作用。但它是一个抽象的基类,Type有与每种数据类型对应的派生类,我们使用这个派生类的对象的方法、字段、属性来查找有关该类型的所有信息。
    获取给定类型的Type引用有3种常用方式:
    
●使用 C# typeof 运算符。
        Type t = typeof(string);
    ●使用对象GetType()方法。
        string s = "grayworm";
        Type t = s.GetType(); 
    ●还可以调用Type类的静态方法GetType()。
        Type t = Type.GetType("System.String");
 
方法大概就这样 具体情况具体分析 

转载于:https://www.cnblogs.com/smallxin/p/4543860.html

你可能感兴趣的文章
手机端userAgent
查看>>
pip安装Mysql-python报错EnvironmentError: mysql_config not found
查看>>
http协议组成(请求状态码)
查看>>
怎样成为一个高手观后感
查看>>
[转]VC预处理指令与宏定义的妙用
查看>>
MySql操作
查看>>
python 解析 XML文件
查看>>
MySQL 文件导入出错
查看>>
java相关
查看>>
由一个异常开始思考springmvc参数解析
查看>>
向上扩展型SSD 将可满足向外扩展需求
查看>>
虚机不能启动的特例思考
查看>>
SQL Server编程系列(1):SMO介绍
查看>>
在VMware网络测试“专用VLAN”功能
查看>>
使用Formik轻松开发更高质量的React表单(三)<Formik />解析
查看>>
也问腾讯:你把用户放在什么位置?
查看>>
CSS Sprites 样式生成工具(bg2css)
查看>>
[转]如何重构代码--重构计划
查看>>
类中如何对list泛型做访问器??
查看>>
C++解析XML--使用CMarkup类解析XML
查看>>