通过Demo来细看C#事件的内在机制
2010-09-30 22:44:34 来源:WEB开发网 闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鎯у⒔閹虫捇鈥旈崘顏佸亾閿濆簼绨绘い鎺嬪灪閵囧嫰骞囬姣挎捇鏌熸笟鍨妞ゎ偅绮撳畷鍗炍旈埀顒勭嵁婵犲嫮纾介柛灞捐壘閳ь剛鎳撻~婵嬪Ω閳轰胶鐤呯紓浣割儐椤戞瑩宕ョ€n喗鐓曟い鎰靛亝缁舵氨绱撻崘鈺傜婵﹤顭峰畷鎺戔枎閹搭厽袦婵犵數濮崑鎾绘⒑椤掆偓缁夌敻骞嗛悙鍝勭婵烇綆鍓欐俊鑲╃磼閹邦収娈滈柡灞糕偓鎰佸悑閹肩补鈧尙鏁栧┑鐐村灦閹稿摜绮旈悽绋课﹂柛鏇ㄥ灠閸愨偓濡炪倖鍔﹀鈧繛宀婁邯濮婅櫣绱掑Ο璇茶敿闂佺ǹ娴烽弫璇差嚕婵犳碍鏅插璺猴工瀹撳棝姊虹紒妯哄缂佷焦鎸冲畷鎴﹀箻鐠囧弶宓嶅銈嗘尰缁嬫垶绂嶉悙顒佸弿婵☆垳鍘ф禍楣冩倵濮樼偓瀚�

private ProcessEventHandler processEvent;
[MethodImpl(MethodImplOptions.Synchronized)]
public void add_processEvent(ProcessEventHandler value)
{
this.processEvent = (ProcessEventHandler)Delegate.Combine(this.processEvent, value);
}
[MethodImpl(MethodImplOptions.Synchronized)]
public void remove_processEvent(ProcessEventHandler value)
{
this.processEvent = (ProcessEventHandler)Delegate.Remove(this.processEvent, value);
}
OK,现在已经明确了,processEvent确实是ProcessEventHandler类型的委托,只不过不管是申明为public,它总是被申明为Private。另外,它还增加了两个方法,分别是add_processEvent和remove_processEvent方法,这两个方法分别用于注册委托类型的方法和取消注册。实际上也就是:“+=”对应add_processEvent,“-=”对应remove_processEvent。而这两个方法的访问限制取决于申明事件的访问修饰符。
我们也可以看到在add_processEvent()方法内部,实际上是调用了System.Delegate的Combine()的静态方法,这个方法用于将当前的变量添加到委托链中。
我们前面说:委托实际上是一个类。也就是说当编译器遇到
public delegate void ProcessEventHandler(string name)
代码的时候,会生成下面这样一个类:
public sealed class ProcessEventHandler : System.MulticastDelegate
{
[MethodImpl(0, MethodCodeType = MethodCodeType.Runtime)]
public ProcessEventHandler(object @object, IntPtr method);
[MethodImpl(0, MethodCodeType = MethodCodeType.Runtime)]
public virtual IAsyncResult BeginInvoke(string name, AsyncCallback callback, object @object);
[MethodImpl(0, MethodCodeType = MethodCodeType.Runtime)]
public virtual void EndInvoke(IAsyncResult result);
[MethodImpl(0, MethodCodeType = MethodCodeType.Runtime)]
public virtual void Invoke(string name);
}
更多精彩
赞助商链接