C#事件及委托揭秘
2011-10-25 22:00
267 查看
定义一个委托:
编译器后台生成的代码:
定义一个事件成员:
编译器后台生成的代码:
注册事件处理器,实际上就是在委托链表里增加委托对象
public delegate void MailMsgEventHandler(Object sender, MailMsgEventArgs args);
编译器后台生成的代码:
public class MailMsgEventHandler: System.MulticastDelegate { // 构造器,第一个参数为调用方法的对象(静态方法为null),第二个参数为方法指针 public MailMsgEventHandler(Object target, Int32 methodPtr); // 该方法使用MulticastDelegate的Target和Method属性来调用委托封装的方法 public void virtual Invoke(Object sender, MailMsgEventArgs args); // 下面两个方法允许对委托进行异步回调 public virtual IAsycResult BeginInvoke(Object sender, MailMsgEventArgs args, AsyncCallback callback, Object object); public virtual void EndInvoke(IAsycResult result); }
定义一个事件成员:
public event MailMsgEventHandler MailMsg;
编译器后台生成的代码:
// 1、一个被初始化为null的私有委托类型字段 private MailMsgEventHandler MailMsg; // 2、一个允许对象添加事件处理器的公有add_*方法,对委托实例调用“+=”操作符时转换为对该方法的调用 public virtual void add_MailMsg(MailMsgEventHandler handler) { MailMsg = (MailMsgEventHandler )Delegate.Combine(MailMsg, handler); } // 3、一个允许对象删除事件处理器的公有remove_*方法,对委托实例调用“-=”操作符时转换为对该方法的调用 public virtual void remove_MailMsg(MailMsgEventHandler handler) { MailMsg = (MailMsgEventHandler )Delegate.Remove(MailMsg, handler); }
注册事件处理器,实际上就是在委托链表里增加委托对象
class cls; cls obj = new cls(); MailMsg += new MailMsgEventHandler(obj.Fun);// 添加实例方法 // 编译器后台代码 MailMsg.add_MailMsg(new MailMsgEventHandler(obj, cls.Fun)); Mailmsg += new MailMsgEventHandler(cls.Fun);// 添加静态方法 // 编译器后台代码 MailMsg.add_MailMsg(new MailMsgEventHandler(null, cls.Fun));
相关文章推荐
- C#实战揭秘:深入解析委托与事件的由来
- C#综合揭秘——深入分析委托与事件
- C#综合揭秘——深入分析委托与事件
- C#综合揭秘——深入分析委托与事件
- C#综合揭秘——深入分析委托与事件
- C#综合揭秘——深入分析委托与事件(上) 推荐
- C#综合揭秘——深入分析委托与事件
- C#综合揭秘——深入分析委托与事件(中)
- C#综合揭秘——深入分析委托与事件(下)
- C#综合揭秘——深入分析委托与事件
- C#综合揭秘——深入分析委托与事件(中)
- C#综合揭秘——深入分析委托与事件
- 深入浅出----C#中委托与事件
- C# 中的委托和事件
- C# 中的委托和事件
- C#中的委托、事件和设计模式(转载)
- 14 C# 第十三章 事件和委托(一) 多播委托的问题
- C# 中的委托和事件
- C# 窗体加载事件委托被忽视的环节?委托事件声明定义
- c#关于委托和事件