• <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 小果子 閱讀(432) 評論(0)  編輯 收藏 引用 所屬分類: .Net
            无码八A片人妻少妇久久| 久久久久久久女国产乱让韩| 久久国产精品成人影院| 国产精品美女久久久| 久久99精品国产麻豆不卡| 尹人香蕉久久99天天拍| 精品久久久久久亚洲| 久久国产综合精品五月天| 亚洲国产另类久久久精品| 一级做a爰片久久毛片人呢| 亚洲第一永久AV网站久久精品男人的天堂AV | 国产精品久久久久9999| 久久九色综合九色99伊人| 色婷婷综合久久久久中文| 91精品久久久久久无码| 亚洲精品无码久久一线| 亚洲精品无码久久久久AV麻豆| 久久精品无码专区免费东京热| 一本一本久久a久久精品综合麻豆| 99久久成人国产精品免费| 99久久这里只精品国产免费| 99久久国产主播综合精品| 国产精品无码久久综合| 亚洲精品乱码久久久久66| 色综合久久中文字幕综合网| 国产精品99久久久久久人| 久久免费的精品国产V∧| 2021国产精品久久精品| 亚洲国产精品综合久久网络| 久久久网中文字幕| 精品久久久久中文字幕一区| 久久夜色tv网站| 国产精品日韩深夜福利久久| 久久91精品久久91综合| 99久久精品国内| 99久久国语露脸精品国产| 久久99毛片免费观看不卡| 久久精品这里热有精品| 91精品国产色综久久| 久久综合成人网| 久久综合亚洲色HEZYO社区|