CodeDom系列--事件(event)定义和反射调用

简介:

    CodeDom提供了对事件的支持,以及我们可以用反射机制对CodeDom生成的事件进行注册,以及调用。本节程序很简单,先贴上我将用CodeDom生成的代码:

namespace CodeDomDemo3
{
using System;
public class CodeDomDemo3
{
public event System.EventHandler MyEvent;
protected virtual void OnHandle(System.EventArgs e)
{
if ((this.MyEvent != null))
{
this.MyEvent(this, e);
}
}
public void CallEvent()
{
this.OnHandle(EventArgs.Empty);
}
}
}

代码很简单哦,主要是看CodeDom的事件定义机制和反射调用CodeDom编译的类型方法事件。

CodeDom代码为:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.CodeDom;
namespace CodeDomDemo1
{
public class CodeDomDemo3
{
public CodeNamespace CreateCodeNamespcae()
{
CodeNamespace nspcae = new CodeNamespace("CodeDomDemo3");
nspcae.Imports.Add(new CodeNamespaceImport("System"));
nspcae.Types.Add(CrateClassType());
return nspcae;
}
public CodeTypeDeclaration CrateClassType()
{
//field event
CodeMemberEvent myevent = new CodeMemberEvent();
myevent.Attributes = MemberAttributes.Public;
myevent.Type = new CodeTypeReference(typeof(EventHandler));
myevent.Name = "MyEvent";
// event method OnHandle;
CodeMemberMethod method = new CodeMemberMethod();
method.Name = "OnHandle";
method.Attributes = MemberAttributes.Family;
method.Parameters.Add(new CodeParameterDeclarationExpression(new CodeTypeReference(typeof(EventArgs)), "e"));
method.Statements.Add(new CodeConditionStatement(new CodeBinaryOperatorExpression(new CodeEventReferenceExpression(
new CodeThisReferenceExpression(),"MyEvent"),
CodeBinaryOperatorType.IdentityInequality,new CodePrimitiveExpression(null)),
new CodeExpressionStatement(new CodeDelegateInvokeExpression(new CodeEventReferenceExpression(
new CodeThisReferenceExpression(),
"MyEvent"), new CodeExpression[] { new CodeThisReferenceExpression(), new CodeArgumentReferenceExpression("e"),
}))));
CodeMemberMethod callEvent = new CodeMemberMethod();
callEvent.Name = "CallEvent";
callEvent.Attributes = MemberAttributes.Public | MemberAttributes.Final;
callEvent.Statements.Add(new CodeMethodInvokeExpression(new CodeThisReferenceExpression(), "OnHandle", new CodeExpression[]
 {new CodePropertyReferenceExpression(new CodeTypeReferenceExpression("EventArgs"),"Empty") }));
CodeTypeDeclaration myclass = new CodeTypeDeclaration("CodeDomDemo3");
myclass.Attributes = MemberAttributes.Public;
myclass.Members.AddRange(new CodeTypeMember[] { myevent, method, callEvent });
return myclass;
}
}
}
1:主要注意委托的调用:
public CodeDelegateInvokeExpression(
CodeExpression targetObject,//事件的引用
CodeExpression[] parameters//参数
)
2:事件的添加(+=):
public CodeAttachEventStatement(
CodeExpression targetObject,//目标对象
string eventName,//事件名
CodeExpression listener//监听者
)
3:事件的移除(-=):
public CodeRemoveEventStatement(
CodeExpression targetObject,//目标对象
string eventName,//事件名
CodeExpression listener//监听者
)
   利用反射调用事件代码:
Type t = result.CompiledAssembly.GetType("CodeDomDemo3.CodeDomDemo3");//获取类型
object obj= Activator.CreateInstance(t);//创建实例
t.GetEvent("MyEvent").AddEventHandler(obj, new EventHandler(pro.CallEvent));//添加事件
t.GetMethod("CallEvent").Invoke(obj, null);//触发事件

本示例代码下载:CodeDomDemo3



本文转自破狼博客园博客,原文链接:http://www.cnblogs.com/whitewolf/archive/2010/06/22/1762589.html,如需转载请自行联系原作者

目录
相关文章
|
小程序
小程序--event对象
小程序--event对象
395 0
小程序--event对象
|
C#
C# 从1到Core--委托与事件(三)
委托与事件在C#1.0的时候就有了,随着C#版本的不断更新,有些写法和功能也在不断改变。本文温故一下这些改变,以及在NET Core中关于事件的一点改变。
145 0
|
C#
C# 从1到Core--委托与事件(二)
 委托与事件在C#1.0的时候就有了,随着C#版本的不断更新,有些写法和功能也在不断改变。本文温故一下这些改变,以及在NET Core中关于事件的一点改变。
150 0
|
C#
C# 从1到Core--委托与事件(一)
 委托与事件在C#1.0的时候就有了,随着C#版本的不断更新,有些写法和功能也在不断改变。本文温故一下这些改变,以及在NET Core中关于事件的一点改变。
182 0