本文整理匯總了C#中EventHandler.GetType方法的典型用法代碼示例。如果您正苦於以下問題:C# EventHandler.GetType方法的具體用法?C# EventHandler.GetType怎麽用?C# EventHandler.GetType使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類EventHandler
的用法示例。
在下文中一共展示了EventHandler.GetType方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: LispDelegate
public LispDelegate(LispEventProducer prod, object target, EventInfo method)
//: base(target, method.Name)
{
Target = target;
Producer = prod;
Method = method;
Handler = Invoke;
Type t = target.GetType();
// In order to create a method to handle the Elapsed event,
// it is necessary to know the signature of the delegate
// used to raise the event. Reflection.Emit can then be
// used to construct a dynamic class with a static method
// that has the correct signature.
// Get the event handler type of the Elapsed event. This is
// a delegate type, so it has an Invoke method that has
// the same signature as the delegate. The following code
// creates an array of Type objects that represent the
// parameter types of the Invoke method.
//
Type handlerType = method.EventHandlerType;
MethodInfo invokeMethod = handlerType.GetMethod("Invoke");
ParameterInfo[] parms = invokeMethod.GetParameters();
Type[] parmTypes = new Type[parms.Length];
for (int i = 0; i < parms.Length; i++)
{
parmTypes[i] = parms[i].ParameterType;
}
if (false)
{
// Use Reflection.Emit to create a dynamic assembly that
// will be run but not saved. An assembly must have at
// least one module, which in this case contains a single
// type. The only purpose of this type is to contain the
// event handler method. (In the .NET Framework version
// 2.0 you can use dynamic methods, which are simpler
// because there is no need to create an assembly, module,
// or type.)
AssemblyName aName = new AssemblyName();
aName.Name = "DynamicTypes";
AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly(aName, AssemblyBuilderAccess.Run);
ModuleBuilder mb = ab.DefineDynamicModule(aName.Name);
TypeBuilder tb = mb.DefineType("Handler", TypeAttributes.Class | TypeAttributes.Public);
var localHandler = this.GetType().GetMethod("Invoke");
ConstructorBuilder Ctor = tb.DefineConstructor(MethodAttributes.Public, CallingConventions.Standard,
null);
{
ILGenerator ilc = Ctor.GetILGenerator();
ilc.Emit(OpCodes.Ldarg_0);
ilc.Emit(OpCodes.Call, typeof (object).GetConstructor(new Type[0]));
ilc.Emit(OpCodes.Ret);
}
// Create the method that will handle the event. The name
// is not important. The method is static, because there is
// no reason to create an instance of the dynamic type.
//
// The parameter types and return type of the method are
// the same as those of the delegate's Invoke method,
// captured earlier.
MethodBuilder handler = tb.DefineMethod("DynamicHandler",
MethodAttributes.Public | MethodAttributes.Static,
invokeMethod.ReturnType, parmTypes);
// Generate code to handle the event.
//
ILGenerator il = handler.GetILGenerator();
il.Emit(OpCodes.Ldarg_0);
il.Emit(OpCodes.Ldarg_1);
il.EmitCall(OpCodes.Call, localHandler, new Type[] {typeof (object), typeof (EventArgs)});
il.Emit(OpCodes.Ret);
// CreateType must be called before the Handler type can
// be used. In order to create the delegate that will
// handle the event, a MethodInfo from the finished type
// is required.
Type finished = tb.CreateType();
eventHandler = finished.GetMethod("DynamicHandler");
}
if (true)
{
handlerType = Handler.GetType();
eventHandler = this.GetType().GetMethod("Invoke");
}
// Use the MethodInfo to create a delegate of the correct
// type, and call the AddEventHandler method to hook up
// the event.
Delegate d = Delegate.CreateDelegate(handlerType, eventHandler);
//typeof(object)
//method.EventHandlerType.
//method.AddEventHandler(target, d);
// Late-bound calls to the Interval and Enabled property
// are required to enable the timer with a one-second
// interval.
//t.InvokeMember("Interval", BindingFlags.SetProperty, null, timer, new Object[] { 1000 });
//t.InvokeMember("Enabled", BindingFlags.SetProperty, null, timer, new Object[] { true });
//.........這裏部分代碼省略.........