• <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 - 我并不覺的自豪,我所嘗試的事情都失敗了······習(xí)慣原本生活的人不容易改變,就算現(xiàn)狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預(yù)料,人們需要更細心的觀察別人,要隨時注意才能保護別人,因為他們未必知道自己要什么·····
            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.定義一個類型,保存所有傳遞參數(shù)。
            .net框架規(guī)定所有的信息類型繼承于EventArgs,類型名稱以EventArgs結(jié)束,EventArgs原型如下:
            [Serializable]
            public class EventArgs
            {
                public static readonly EventArgs Empty = new EventArgs();
                public EventArgs(){};
            }
            只有一個靜態(tài)的Empty成員,因為事件中有些不需要額外的參數(shù)信息,所以只要提供EventArgs.Empty,不需要在構(gòu)造新的對象
            2.定義一個委托類型,指定事件觸發(fā)時調(diào)用的函數(shù)原型
            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.定義驅(qū)動事件方法
            public virtual void SimulateArrivingMsg(String from, String to, String subject, String body);

            深入理解事件
            當編譯器遇到
            public event MailEventHandler MailMsg;
            會產(chǎn)生3個構(gòu)造,一個私有委托類型,及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內(nèi)_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;
                    }
                }

            注意,當一個對象仍然登記有另外一個對象的事件,該對象就不可能對垃圾回收,如果我們類實現(xiàn)了IDisposable接口,那我們應(yīng)該在
            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;定義

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

            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 框架設(shè)計一個example,如果設(shè)計該種事件類型,其中給出了EventHandlerSet的實現(xiàn),
            .net框架中也有類似的事件 EventHandlerList,但是訪問效率和線程同步有缺陷,所以有需要我們自己提供
            EventHandlerSet實現(xiàn).詳情請參考microsoft .net 框架設(shè)計

            posted on 2010-09-30 14:17 小果子 閱讀(437) 評論(0)  編輯 收藏 引用 所屬分類: .Net

            只有注冊用戶登錄后才能發(fā)表評論。
            相關(guān)文章:
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            亚洲?V乱码久久精品蜜桃| 精品无码久久久久久午夜| 久久久WWW成人免费毛片| 亚洲国产小视频精品久久久三级 | 伊人久久综合无码成人网| 亚洲精品无码久久千人斩| 国产69精品久久久久99尤物| 亚洲七七久久精品中文国产| 91精品国产色综合久久| 亚洲午夜久久久| 93精91精品国产综合久久香蕉| 亚洲国产视频久久| 国产精品一区二区久久精品无码 | 久久精品国产一区二区| 无码AV中文字幕久久专区| 热综合一本伊人久久精品 | 99国产欧美精品久久久蜜芽| 久久精品综合网| 无码8090精品久久一区 | 精品精品国产自在久久高清 | 久久久久人妻精品一区| 热久久最新网站获取| 久久本道久久综合伊人| 91精品婷婷国产综合久久| 精品久久8x国产免费观看| 久久久久久久久久久久久久| 欧美亚洲另类久久综合婷婷| 精品国产青草久久久久福利| 午夜不卡888久久| 99久久精品影院老鸭窝| 精品久久久久久无码专区不卡| 午夜精品久久久久久99热| 亚洲国产一成人久久精品| 狠狠色噜噜色狠狠狠综合久久 | 精品永久久福利一区二区| 亚洲乱码精品久久久久..| 亚洲AV无码成人网站久久精品大| 伊人久久大香线蕉综合影院首页| 久久国产免费直播| 亚洲国产精品18久久久久久| 久久99精品久久久大学生|