天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

把委托說透(4):委托與設計模式

委托與很多設計模式都有著千絲萬縷的聯系,在前面的隨筆中已經介紹了委托與策略模式的聯系,本節主要來討論委托與其他兩個模式:觀察者模式和模板方法模式。

委托與觀察者模式

在.NET中,很多設計模式得到了廣泛應用,如foreach關鍵字實現了迭代器模式。同樣的,.NET中也內置了觀察者模式的實現方式,這種方式就是委托。

觀察者模式的一般實現

網上可以找到很多資料介紹觀察者模式的實現,我這里介紹一種簡單的退化后的觀察者模式,即Subject類為具體類,在其之上不再進行抽象。

public class Subject{    private List<Observer> observers = new List<Observer>();    private string state;    public string State    {        set        {            state = value;            NotifyObservers();        }        get { return state; }    }    public void RegisterObserver(Observer ob)    {        observers.Add(ob);    }    public void RemoveObserver(Observer ob)    {        observers.Remove(ob);    }    public void NotifyObservers()    {        foreach (Observer ob in observers)            ob.Update(this);    }}public abstract class Observer{    public abstract void Update(Subject subject);}public class ConsoleObserver : Observer{    public ConsoleObserver(Subject subject)    {        subject.RegisterObserver(this);    }    public override void Update(Subject subject)    {        Console.WriteLine("Subject has changed its state : " + subject.State);    }}

調用的方法很簡單:

Subject subject = new Subject();Observer observer = new ConsoleObserver(subject);subject.State = "Kirin Yao";

Subject類維護一個列表,負責觀察者的注冊和移除。當其狀態發生改變時,就調用NotifyObservers方法通知各個觀察者。

觀察者模式的委托實現

在.NET中,使用委托可以更簡單更優雅地實現觀察者模式。在上一篇隨筆中,最后的示例其實就是一個觀察者模式。MainForm為Subject,SubForm為Observer。當MainForm的狀態發生改變時(即點擊“傳值”按鈕時),SubForm作為觀察者響應來自MainForm的變化。

與上例對應的,用委托實現的觀察者模式的代碼大致如下:

namespace DelegateSample{    class UpdateEventArgs : EventArgs { }    class Subject    {        private string state;        public string State         {            get { return state; }            set             {                state = value;                OnUpdate(new UpdateEventArgs());            }        }        public event EventHandler<UpdateEventArgs> Update;        public void ChangeState(string state)        {            this.State = state;            OnUpdate(new UpdateEventArgs());        }        private void OnUpdate(UpdateEventArgs e)        {            EventHandler<UpdateEventArgs> handler = Update;            if (handler != null)                Update(this, e);        }    }    abstract class Observer    {        public Subject Subject { get; set; }        public Observer(Subject subject)        {            this.Subject = subject;            this.Subject.Update += new EventHandler<UpdateEventArgs>(Subject_Update);        }        protected abstract void Subject_Update(object sender, UpdateEventArgs e);    }    class ConsoleObserver : Observer    {        public ConsoleObserver(Subject subject) : base(subject) { }        protected override void Subject_Update(object sender, UpdateEventArgs e)        {            Subject subject = sender as Subject;            if (subject != null)                Console.WriteLine("Subject has changed its state : " + subject.State);        }    }    class Program    {        static void Main(string[] args)        {            Subject subject = new Subject();            Observer ob = new ConsoleObserver(subject);            subject.State = "Kirin Yao";            Console.ReadLine();        }    }}

相比傳統的觀察者模式的實現方式(在Subject中維護一個Observer列表),使用委托避免了Subject與Observer之間的雙向引用,Subject作為主題類,對觀察者毫無所知,降低了耦合性,語法上也更加優雅。

委托與模板方法模式

模板方法模式封裝了一段通用的邏輯,將邏輯中的特定部分交給子類實現。

public abstract class AbstractClass{    public void Arithmetic()    {        SubArithmeticA();        SubArithmeticB();        SubArithmeticC();    }    protected abstract void SubArithmeticA();    protected abstract void SubArithmeticB();    protected abstract void SubArithmeticC();}public class ConcreteClass : AbstractClass{    protected override void SubArithmeticA()    {        //...    }    protected override void SubArithmeticB()    {        //...    }    protected override void SubArithmeticC()    {        //...    }}

然而這種繼承方式的模板方法耦合度較高,特別是如果邏輯與其外部實現沒有必然的從屬關系的時候,用傳統的模板方法就顯得不那么合適了。

在某種程度上,委托可以看做是一個輕量級的模板方法實現方式,它將邏輯中的特定部分轉交給注冊到委托的方法來實現。從而替代了繼承方式的模板方法模式中,在子類中實現特定邏輯的方式。

public delegate void SubArithmetic();public class ConcreteClass{    public void Arithmetic()    {        if (SubArithmetic != null)            SubArithmetic();    }    public SubArithmetic SubArithmetic { get; set; }}

而SubArithmetic的實現交給外部:

ConcreteClass concrete = new ConcreteClass();concrete.SubArithmetic = Program.SomeMethod;concrete.Arithmetic();

咋一看在客戶端中編寫委托的方法似乎還略顯麻煩,但值得注意的是,匿名方法和Lambda表達式為我們提供了更加簡便的委托語法。在函數式編程日益盛行的今天,我們應該為.NET提供的這種語言特性而感到慶幸。

NET技術把委托說透(4):委托與設計模式,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产又黄又粗又爽又色的视频软件 | 德国美女密密麻麻浓毛 | 国产亚洲精品久久久久久白晶晶 | 日日噜噜噜噜夜夜爽亚洲精品 | 青青久久精品 | 天美传媒色情原创精品 | 国产欧美日韩精品a在线观看高清 | 色琪琪久久热在线 | 亚洲欧洲精品A片久久99 | 亚洲免费视频在线 | 亚洲高清一区二区三区电影 | 久久午夜伦理 | 国产AV亚洲国产AV麻豆 | 精品国产自在自线官方 | 日产日韩亚洲欧美综合搜索 | 亚洲第一综合天堂另类专 | FREE乌克兰嫩交HD | 男女疯狂一边摸一边做羞羞视频 | 国产欧美精品一区二区三区-老狼 | 接吻吃胸摸下面啪啪教程 | 被老师按在办公桌吸奶头 | 国产永久免费观看视频软件 | www.青青草| 狠狠躁日日躁人人爽 | 十分钟免费看完整视频 | 扒开黑女人p大荫蒂老女人 扒开粉嫩的小缝末成年小美女 | 亚洲精品国产在线网站 | 欧美日韩精品一区二区三区四区 | 乱精品一区字幕二区 | 久久综合中文字幕佐佐木希 | ankha成人 | 成人伊人青草久久综合网 | 暖暖日本免费播放 | 免费视频国产在线观看网站 | 脱女学小内内摸出水网站免费 | 最近免费视频中文2019完整版 | 欧美gv明星 | 2020最新无码国产在线视频 | 久久全国免费观看视频 | 蜜桃传媒在线观看 | 老司机福利视频一区在线播放 |