zoukankan      html  css  js  c++  java
  • 反射事件参数

    namespace ConsoleApplication
    {
        class Program
        {
            public static  void s_TestEvent(string msg)
            {
                Console.WriteLine(msg);
            }

            static void Main(string[] args)
            {
                Assembly ass = Assembly.Load("ConsoleApplication");

                object structInstance = ass.CreateInstance("ConsoleApplication.PrivateField");

                Type structType = structInstance.GetType();


                EventInfo eventInfo = structType.GetEvent("TestEvent", BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Public | BindingFlags.Static);

                Type tDelegate = eventInfo.EventHandlerType;

                MethodInfo miHandler = typeof(Program).GetMethod("s_TestEvent", BindingFlags.Public  | BindingFlags.Static);



                Delegate d = Delegate.CreateDelegate(tDelegate, miHandler);

                MethodInfo miAddHandler = eventInfo.GetAddMethod();

                object[] addHandlerArgs = { d };

                miAddHandler.Invoke(structInstance, addHandlerArgs);

                FieldInfo _Field = structType.GetField("TestEvent", BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Public | BindingFlags.Static);

                if (_Field != null)
                {
                    object _FieldValue = _Field.GetValue(structInstance);

                    if (_FieldValue != null && _FieldValue is Delegate)
                    {
                        Delegate _ObjectDelegate = _FieldValue as Delegate;       

                        _ObjectDelegate.DynamicInvoke(new object[] {"Sandy" });
                    }
                }
            }
        }
    }        

  • 相关阅读:
    导入.txt数据
    struts1与struts2
    居中问题
    JavaScript创建对象的几种方式
    json
    react模拟后端接口及提交方式
    react受控组件
    react中数据承载props和state用法
    react组件间的通信父子通信,子父通信,兄弟通信
    react模拟后端接口及提交方式 jsonserver
  • 原文地址:https://www.cnblogs.com/dlbird/p/3975024.html
Copyright © 2011-2022 走看看