设计模式(C#)

一:工厂模式

  • 目的:定义一个创建对象的接口,让其子类决定实例化哪个工厂类,工厂模式使其常见对象的过程延迟到子类进行
  • 主要解决:主要解决接口选择问题
  • 如何解决:让其子类实现工厂接口,返回的也是一个抽象产品
  • 关键代码:创建过程在其子类执行
  • 应用实例:您需要一辆汽车,可以直接从工厂里面提货,而不用去管这辆汽车是怎么做出来的,以及这个汽车里面的具体实现。
  • **优点: **1、一个调用者想创建一个对象,只要知道其名称就可以了。 2、扩展性高,如果想增加一个产品,只要扩展一个工厂类就可以。 3、屏蔽产品的具体实现,调用者只关心产品的接口。
  • 缺点:每次增加一个产品时,都需要增加一个具体类和对象实现工厂,使得系统中类的个数成倍增加,在一定程度上增加了系统的复杂度,同时也增加了系统具体类的依赖,这并不是什么好事。
  • 注意事项:作为一种创建类模式,在任何需要生成复杂对象的地方,都可以使用工厂方法模式。有一点需要注意的地方就是复杂对象适合使用工厂模式,而简单对象,特别是只需要通过 new 就可以完成创建的对象,无需使用工厂模式。如果使用工厂模式,就需要引入一个工厂类,会增加系统的复杂度。

实现

/// <summary>
    /// 生产PC的工厂接口
    /// </summary>
    public interface PC
    {
        void Make();
    }
    /// <summary>
    /// 生产Phone的工厂接口
    /// </summary>
    public interface Phone
    {
        void Make();
    }
    /// <summary>
    /// 总工厂 (抽象工厂模式)
    /// </summary>
    public interface AbstractFactory
    {
        Phone MakePhone();
        PC MakePC();
    }

    /// <summary>
    /// 小米生产PC的工厂
    /// </summary>
    public class MIPc : PC
    {
        public MIPc()
        {
            this.Make();
        }
        public void Make()
        {
            Console.WriteLine("小米PC");
        }
    }
    /// <summary>
    /// 小米生产Phone的工厂
    /// </summary>
    public class MiPhone:Phone
    {
        public MiPhone()
        {
            this.Make();
        }
        public void Make()
        {
            Console.WriteLine("小米Phone");
        }
    }

    /// <summary>
    /// 苹果生产PC的工厂
    /// </summary>
    public class MAC : PC
    {
        public MAC()
        {
            this.Make();
        }
        public void Make()
        {
            Console.WriteLine("苹果PC");
        }
    }
    /// <summary>
    /// 苹果生产iPone的工厂
    /// </summary>
    public class iPhone : Phone
    {
        public iPhone()
        {
            this.Make();
        }
        public void Make()
        {
            Console.WriteLine("苹果iPhone");
        }
    }

    /// <summary>
    /// 小米工厂(生产手机pc)
    /// </summary>
    public class XiaoMiFactory : AbstractFactory
    {
        public PC MakePC()
        {
            return new MIPc();
        }

        public Phone MakePhone()
        {
            return new MiPhone();
        }
    }

    /// <summary>
    /// 苹果工厂(生产手机pc)
    /// </summary>
    public class AppleFactory : AbstractFactory
    {
        public PC MakePC()
        {
            return new MAC();
        }

        public Phone MakePhone()
        {
            return new iPhone();
        }
    }
  • *运行结果 *

二:观察者模式

  • 解释: 当对象间存在一对多关系时,则使用观察者模式(Observer Pattern)。比如,当一个对象被修改时,则会自动通知依赖它的对象。观察者模式属于行为型模式。
  • 目的: 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新。
  • 主要解决:一个对象状态改变给其他对象通知的问题,而且要考虑到易用和低耦合,保证高度的协作。
  • 何时使用:一个对象(目标对象)的状态发生改变,所有的依赖对象(观察者对象)都将得到通知,进行广播通知。
  • 如何解决::使用面向对象技术,可以将这种依赖关系弱化。
  • 关键代码:使用事件通知观察者们。
  • 应用实例:1、拍卖的时候,拍卖师观察最高标价,然后通知给其他竞价者竞价。 2、西游记里面悟空请求菩萨降服红孩儿,菩萨洒了一地水招来一个老乌龟,这个乌龟就是观察者,他观察菩萨洒水这个动作。
  • 优点:1、观察者和被观察者是抽象耦合的。2、建立一套触发机制。
  • 缺点:1、如果一个被观察者对象有很多的直接和间接的观察者的话,将所有的观察者都通知到会花费很多时间。 2、如果在观察者和观察目标之间有循环依赖的话,观察目标会触发它们之间进行循环调用,可能导致系统崩溃。 3、观察者模式没有相应的机制让观察者知道所观察的目标对象是怎么发生变化的,而仅仅只是知道观察目标发生了变化。
  • 使用场景:
    • 一个抽象模型有两个方面,其中一个方面依赖于另一个方面。将这些方面封装在独立的对象中使它们可以各自独立地改变和复用。
    • 一个对象的改变将导致其他一个或多个对象也发生改变,而不知道具体有多少对象将发生改变,可以降低对象之间的耦合度。
    • 一个对象必须通知其他对象,而并不知道这些对象是谁。
    • 需要在系统中创建一个触发链,A对象的行为将影响B对象,B对象的行为将影响C对象……,可以使用观察者模式创建一种链式触发机制。
  • 实现:
/// <summary>
    /// 烧水壶类 (烧水壶烧水行为,烧水时温度计温度上升,用电量增加)
    /// </summary>
    public  class ShaoShuiHu
    {
        public delegate void ShaoShuiDele();
        public event ShaoShuiDele ShaoShuiEvt;

        public void BoilWater()
        {
            if (ShaoShuiEvt!=null)
            {
                Console.WriteLine("电水壶 开始烧水。。。。");
                ShaoShuiEvt();
            }
        }
    }
    /// <summary>
    /// 温度计类
    /// </summary>
    public class Thermometer
    {
        //升温
        public void ShengWen()
        {
            Console.WriteLine("温度正在升高!");
        }
    }
    /// <summary>
    /// 电表
    /// </summary>
    public class Meter
    {
        //用电
        public void UseElectric()
        {
            Console.WriteLine("正在用电,用电量正在增加");
        }
    }
  • 运行结果:

原文链接https://www.runoob.com/design-pattern/design-pattern-tutorial.html

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352