• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            xiaoguozi's Blog
            Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習慣原本生活的人不容易改變,就算現狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預料,人們需要更細心的觀察別人,要隨時注意才能保護別人,因為他們未必知道自己要什么·····
            CLR事件機制建立在委托機制上
            class MailManager
                {
                    
            public class MailEventArgs : EventArgs
                    {
                        
            public MailEventArgs(
                            String from,
                            String to,
                            String subject,
                            String body)
                        {
                            
            this.from = from;
                            
            this.to = to;
                            
            this.subject = subject;
                            
            this.body = body;
                        }
                        
            public readonly String from, to, subject, body;
                    }
                    
            public delegate void MailEventHandler(Object sender, MailEventArgs e);
                    
            public event MailEventHandler MailMsg;
                    
            protected virtual void OnMailMsg(MailEventArgs e)
                    {
                        
            if (MailMsg != null)
                        {
                            MailMsg(
            this, e);
                        }
                    }
                    
            public virtual void SimulateArrivingMsg(String from, String to, String subject, String body)
                    {
                        MailEventArgs e 
            = new MailEventArgs(from, to, subject, body);
                        OnMailMsg(e);
                    }
                }
            以上是一個事件類型定義,簡單步驟:
            1.定義一個類型,保存所有傳遞參數。
            .net框架規定所有的信息類型繼承于EventArgs,類型名稱以EventArgs結束,EventArgs原型如下:
            [Serializable]
            public class EventArgs
            {
                public static readonly EventArgs Empty = new EventArgs();
                public EventArgs(){};
            }
            只有一個靜態的Empty成員,因為事件中有些不需要額外的參數信息,所以只要提供EventArgs.Empty,不需要在構造新的對象
            2.定義一個委托類型,指定事件觸發時調用的函數原型
            public delegate void MailEventHandler(Object sender, MailEventArgs e);
            如果事件中并沒有額外的傳遞信息,則可以使用System.EventHandler,原型為
            public delegate void EventHandler(Object sender,EventArgs e);
            3.定義一個事件成員
            public event MailEventHandler MailMsg;
            4.定義受保護的虛方法,通知事件登記對象
            protected virtual void OnMailMsg(MailEventArgs e);
            5.定義驅動事件方法
            public virtual void SimulateArrivingMsg(String from, String to, String subject, String body);

            深入理解事件
            當編譯器遇到
            public event MailEventHandler MailMsg;
            會產生3個構造,一個私有委托類型,及add和remove方法
            private MailEventHandler MailMsg;
            [MethodImplAttribute(MethodImplOptions.Synchronized)]
            public virtual void add_MailMsg(MailEventHandler handler)
            {
                 MailMsg = (MailEventHandler)Delegate.Combine(MailMsg, handler);
            }
            [MethodImplAttribute(MethodImplOptions.Synchronized)]
            public virtual void remove_MailMsg(MailEventHandler handler)
            {
                 MailMsg = (MailEventHandler)Delegate.Remove(MailMsg, handler);
            }
            通過MailMsg內_prev字段可以將添加的注冊對象保存

            偵聽事件
            class Fax
                {
                    public Fax(MailManager mm)
                    {
                        mm.MailMsg += new MailManager.MailEventHandler(FaxMsg);
                    }
                    private void FaxMsg(Object sender, MailManager.MailEventArgs e)
                    {

                    }
                    public void UnRegister(MailManager mm)
                    {
                        MailManager.MailEventHandler callback = new MailManager.MailEventHandler(FaxMsg);
                        mm.MailMsg -= callback;
                    }
                }

            注意,當一個對象仍然登記有另外一個對象的事件,該對象就不可能對垃圾回收,如果我們類實現了IDisposable接口,那我們應該在
            Dispose理注銷所有登記事件

            顯示控制事件注冊
            private MailEventHandler mailMsgEventHandlerDelegate;
                    public event MailEventHandler MailMsg
                    {
                        add
                        {
                            mailMsgEventHandlerDelegate =(MailEventHandler)Delegate.Combine(mailMsgEventHandlerDelegate, value);
                        }
                        remove
                        {
                            mailMsgEventHandlerDelegate = (MailEventHandler)Delegate.Remove(mailMsgEventHandlerDelegate, value);
                        }
                    }
                    protected virtual void OnMailMsg(MailEventArgs e)
                    {
                        if (MailMsg != null)
                        {
                            mailMsgEventHandlerDelegate(this, e);
                        }
                    }

            來代替
            public event MailEventHandler MailMsg;定義

            當一個類型中含有多個事件時,由于每個事件事例聲明都將產生委托字段,所以推薦
            不要提供公共的事件成員變量,使用事件訪問器替換這些變量

            class EventHandlerSet:IDisposable
                {
                    private Hashtable events = new Hashtable();
                    public virtual Delegate this[Object eventKey]
                    {
                        get
                        {
                            return (Delegate)events[eventKey];
                        }
                        set
                        {
                            events[eventKey] = value;
                        }
                    }
                    public virtual void AddHandler(Object eventKey,Delegate handler)
                    {
                        events[eventKey] = Delegate.Combine((Delegate)events[eventKey], handler);
                    }
                    public virtual void RevHandler(Object eventKey, Delegate handler)
                    {
                        events[eventKey] = Delegate.Remove((Delegate)events[eventKey], handler);
                    }
                    public virtual void Fire(Object eventKey, Object sender, EventArgs e)
                    {
                        Delegate d = (Delegate)events[eventKey];
                        if (d != null)
                            d.DynamicInvoke(new Object[]{sender,e});
                    }
                    public void Dispose()
                    {
                        events = null;
                    }
                    public static EventHandlerSet Synchronized(EventHandlerSet eventHandlerSet)
                    {
                        if (eventHandlerSet == null)
                            throw new ArgumentNullException("eventHandlerSet");
                        return new SynchronizedEventHandlerSet(eventHandlerSet);
                    }
                    public class SynchronizedEventHandlerSet : EventHandlerSet
                    {
                        private EventHandlerSet eventHandlerSet;
                        public SynchronizedEventHandlerSet(EventHandlerSet eventHandlerSet)
                        {
                            this.eventHandlerSet = eventHandlerSet;
                            Dispose();
                        }
                        public override Delegate this[object eventKey]
                        {
                            [MethodImpl(MethodImplOptions.Synchronized)]
                            get
                            {
                                return eventHandlerSet[eventKey];
                            }
                            set
                            {
                                eventHandlerSet[eventKey] = value;
                            }
                        }
                        [MethodImpl(MethodImplOptions.Synchronized)]
                        public override void AddHandler(object eventKey, Delegate handler)
                        {
                            eventHandlerSet.AddHandler(eventKey, handler);
                        }
                        [MethodImpl(MethodImplOptions.Synchronized)]
                        public override void RevHandler(object eventKey, Delegate handler)
                        {
                            eventHandlerSet.RevHandler(eventKey, handler);
                        }
                        [MethodImpl(MethodImplOptions.Synchronized)]
                        public override void Fire(object eventKey, object sender, EventArgs e)
                        {
                            eventHandlerSet.Fire(eventKey, sender, e);
                        }
                    }
                }
                class TypeWithLotsEvents
                {
                    protected EventHandlerSet eventSet = EventHandlerSet.Synchronized(new EventHandlerSet());
                    protected static readonly Object fooEventKey = new Object();
                    public class FooEventArgs : EventArgs { };
                    public delegate void FooEventHandler(Object sender, FooEventArgs e);
                    public event FooEventHandler Foo
                    {
                        add
                        {
                            eventSet.AddHandler(fooEventKey, value);
                        }
                        remove
                        {
                            eventSet.AddHandler(fooEventKey, value);
                        }
                    }
                    protected virtual void OnFoo(FooEventArgs e)
                    {
                        eventSet.Fire(fooEventKey, this, e);
                    }
                    public void SimulateFoo()
                    {
                        OnFoo(new FooEventArgs());
                    }

                }
            以上是microsoft .net 框架設計一個example,如果設計該種事件類型,其中給出了EventHandlerSet的實現,
            .net框架中也有類似的事件 EventHandlerList,但是訪問效率和線程同步有缺陷,所以有需要我們自己提供
            EventHandlerSet實現.詳情請參考microsoft .net 框架設計

            posted on 2010-09-30 14:17 小果子 閱讀(431) 評論(0)  編輯 收藏 引用 所屬分類: .Net
            久久中文骚妇内射| 久久久久久噜噜精品免费直播 | 久久久久久人妻无码| 久久久久人妻一区精品性色av| 77777亚洲午夜久久多喷| 91久久精品国产91性色也| 久久久久久av无码免费看大片| 影音先锋女人AV鲁色资源网久久 | 国产亚洲婷婷香蕉久久精品| 久久99久久无码毛片一区二区| 久久午夜免费视频| 女人香蕉久久**毛片精品| 2021国内久久精品| 国产精品成人99久久久久 | AAA级久久久精品无码片| 久久国产成人午夜aⅴ影院 | 99久久久国产精品免费无卡顿| 国产精品99久久精品爆乳| 久久久无码精品亚洲日韩京东传媒| 97久久天天综合色天天综合色hd | 青青青国产成人久久111网站| 欧美亚洲国产精品久久| 91精品国产91久久久久久蜜臀| 一本久久综合亚洲鲁鲁五月天| 97久久超碰成人精品网站| 亚洲av成人无码久久精品| 亚洲国产精品成人久久蜜臀 | 久久精品无码一区二区WWW | 久久精品欧美日韩精品| 久久影院午夜理论片无码| 国产精品久久午夜夜伦鲁鲁| 一本一本久久A久久综合精品| 香蕉aa三级久久毛片| 久久国产精品波多野结衣AV| 久久电影网一区| 国产午夜福利精品久久2021| 性高湖久久久久久久久| 人妻少妇久久中文字幕一区二区| 99精品久久久久久久婷婷| 久久婷婷五月综合国产尤物app| 久久久久一本毛久久久|