C#设计模式实现之生成器模式和责任链模式

目录
  • 生成器
    • 设计类图:
    • 实现代码:
    • 优点:
    • 用途与缺点:
  • 责任链
    • 设计类图:
    • 实现代码:
    • 优点:
    • 用途和缺点:
  • 总结

生成器

生成器模式:封装一个产品的构造过程,并允许按步骤构造。

现又一个度假计划指定,需要指定度假每一天的活动、旅馆、用餐、门票等等事情,但是每个客人的度假计划可能不太一样。例如天数、活动类型、用餐等等。

我们需要一个弹性的数据结构,代表客人的规划,以及不同的变化,也需要一系列潜在复杂顺序,创建这样的规划。如何提供一种方式来创建复杂的结构,也不会和创建它的步骤混在一起。迭代器的过程就是封装进一个独立的对象中,向客户隐藏集合的内部表现。这里我们也采用同样的思路:我们将旅游规划的创建过程,封装到一个对象中(此对象称为生成器),然后让客户调用生成器为它创建旅游规划。

设计类图:

实现代码:

①存储数据结构类

     public class Vacation
     {
         public int Day { get; set; }
         public string Hotel { get; set; }
         public string Park { get; set; }
         public string Activity { get; set; }
         public string Meal { get; set; }
     }

②抽象生成器

     public abstract class AbstractBuilder
     {
         public abstract void BuildDay(int day);
         public abstract void Hotel(string hotel);
         public abstract void Park(string park);
        public abstract void Activity(string activity);
         public abstract void Meal(string meal);
         public abstract Vacation GetVacationPlanner();
     }

③具体生成器,具体生成器可以多个实现。

     public class VacationBuilder : AbstractBuilder
     {
         private Vacation vacation=new Vacation();

         public override void BuildDay(int day)
         {
             vacation.Day = day;
         }

         public override void Hotel(string hotel)
         {
             vacation.Hotel = hotel;
         }
         public override void Activity(string activity)
         {
             vacation.Activity = activity;
         }
         public override void Meal(string meal)
         {
             vacation.Meal = meal;
         }

         public override void Park(string park)
         {
             vacation.Park = park;
         }

         public override Vacation GetVacationPlanner()
         {
             return vacation;
         }
     }

④客户使用生成器

优点:

1、将复杂对象创建过程封装起来。

2、允许对象通过多个步骤来创建,并且可以改变过程。

3、向客户隐藏产品内部表现。

4、产品的实现可以被替换,因为客户只看到一个抽象的接口。

用途与缺点:

1、经常用来创建组合结构。

2、与工厂模式相比,采用生成器创建对象的客户需要更多的领域知识,才能正确的创建对象。

责任链

责任链模式:让一个以上的对象有机会能够处理某个请求的时候,就使用责任链模式。

有这样一个场景,公司专门接受邮件处理的人员需要将每天接收到的邮件进行处理,一类是需要转给部门经理处理的邮件,一类是给自己处理的,还有一类垃圾邮件直接删除。如果这样的一个场景,我们就可以通过责任链模式,为处理创建一个对象链。每个对象依序检查邮件请求,并进行处理,或者将它传递给链中的下一个对象。

设计类图:

实现代码:

①责任链抽象类

     /// <summary>
     /// 邮件类型
     /// </summary>
     public enum EmailType
     {
         Self=1,
         Manager=2,
         Del=3
     }

     public abstract class Handler
     {
         public Handler nextHandler;
         public EmailType type;

         public Handler(EmailType type) {
             this.type = type;
         }

         public void SetNextHandler(Handler nextHandler)
         {
             this.nextHandler = nextHandler;
         }

         public abstract void HandleRequest(EmailType requsetType);

     }

②责任链处理类

     /// <summary>
     /// 自己处理
     /// </summary>
     class SelfHandler : Handler
     {
         public SelfHandler() : base(EmailType.Self)
         {
         }

         public override void HandleRequest(EmailType requsetType)
         {
             if (EmailType.Self == requsetType)
             {
                 Console.WriteLine("邮件由自己处理");
             }
             else
             {
                 if (nextHandler != null)
                 {
                     nextHandler.HandleRequest(requsetType);
                 }
             }
         }
     }
     /// <summary>
     /// 转发经理
     /// </summary>
     class ManagerHandler : Handler
     {
         public ManagerHandler() : base(EmailType.Manager)
         {
         }

         public override void HandleRequest(EmailType requsetType)
         {
             if (EmailType.Manager == requsetType)
             {
                 Console.WriteLine("邮件转到经理处理");
             }
             else
             {
                 if (nextHandler != null)
                 {
                     nextHandler.HandleRequest(requsetType);
                 }
             }
         }
     }
     /// <summary>
     /// 删除垃圾邮件
     /// </summary>
     class DelHandler : Handler
     {
         public DelHandler() : base(EmailType.Del)
         {
         }

         public override void HandleRequest(EmailType requsetType)
         {
             if (EmailType.Del == requsetType)
             {
                 Console.WriteLine("垃圾邮件已删除");
             }
             else
             {
                 if (nextHandler != null)
                 {
                     nextHandler.HandleRequest(requsetType);
                 }
             }
         }
     }

③测试责任链

     class Program
     {
         static void Main(string[] args)
         {
             //组装责任链
             Handler handler = new SelfHandler();
             Handler handler1 = new ManagerHandler();
             Handler handler2 = new DelHandler();
             handler.SetNextHandler(handler1);
             handler1.SetNextHandler(handler2);
             //测试
             handler.HandleRequest(EmailType.Del);
             handler.HandleRequest(EmailType.Manager);
             handler.HandleRequest(EmailType.Self);

             Console.ReadKey();
         }
     }

优点:

1、请求的发送者和接收者解耦。

2、简化对象,因为不需要知道链的结构。

3、通过改变链内的成员或调动他们的次序,允许你动态地新增或者删除责任。

用途和缺点:

1、经常被用在窗口系统中,处理鼠标和键盘之类的事件。

2、并不保证请求一定被执行,如果没有任何对象处理它,可能会落到链尾端之外。

3、不容易观察允许特征,不好排查问题。

总结

到此这篇关于C#设计模式实现之生成器模式和责任链模式的文章就介绍到这了,更多相关C#生成器模式和责任链模式内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C# Console.WriteLine()用法案例详解

    以前用Console.WriteLine()的时候就只会用它直接输出string字符串,但后来发现它还有其它在有些场合下会十分方便的输出方法,这篇就记录一下这些方法的使用吧. 代码格式我就不写了,因为写了也不好理解,所以直接上示例了.  ① static void Main(string[] args) { int i = 6; string s = "输出"; Console.WriteLine("{0}还可以这样{1}哦.", i, s); Console.Wr

  • c#多线程之间的排他锁的实现

    我们很多时候会碰到这样的问题,使用多线程刷一个表的数据时需要多个线程不能重复提取数据,那么这个时候就需要使用到线程的排他锁了. 在c#里面其实很简单,下面先来看一个简单的小例子 Thread pingTask = new Thread(new ThreadStart(delegate { //从数据库获取1000条数 var list = getdata(); })); //启动线程 pingTask.Start(); 如果这个时候我们开启多个线程 代码如下 for (int i = 0; i

  • C# ExecuteScalar()方法案例讲解

    执行查询,并返回查询所返回的结果集中第一行的第一列.所有其他的列和行将被忽略. 1.返回的是一个object类型,也就是说是所有数据类型的基类,可根据select所得的第一列的数据类型转换为对应的数据类型 例: string strConn = "Data Source=(local);Initial Catalog=paperManage;Integrated Security=True"; SQLConnection objConn = new SQLconnection(strC

  • C# TreeNode案例详解

    目录 添加节点 删除 修改 方法1: 方法二: 添加节点 private void Form1_Load(object sender, EventArgs e) { treeView1.LabelEdit = true;//可编辑状态. //添加一个节点,这个结点是根节点. TreeNode node = new TreeNode(); node.Text = "hope"; treeView1.Nodes.Add(node); TreeNode node1 = new TreeNod

  • 运用示例简单讲解C#取消令牌CancellationTokenSource

    目录 前言 简单示例 基础操作 定时取消 关联取消 判断取消 源码探究 构造入手 小插曲WaitHandle 注册操作 取消操作 Cancel操作 CancelAfter操作 总结 前言 相信大家在使用C#进行开发的时候,特别是使用异步的场景,多多少少会接触到CancellationTokenSource.看名字就知道它和取消异步任务相关的,而且一看便知大名鼎鼎的CancellationToken就是它生产出来的.不看不知道,一看吓一跳.它在取消异步任务.异步通知等方面效果还是不错的,不仅好用而

  • C# NullReferenceException解决案例讲解

    最近一直在写c#的时候一直遇到这个报错,看的我心烦...准备记下来以备后续只需. 参考博客: https://segmentfault.com/a/1190000012609600 一般情况下,遇到这种错误是因为程序代码正在试图访问一个null的引用类型的实体而抛出异常.可能的原因.. 一.未实例化引用类型实体 比如声明以后,却不实例化 using System; using System.Collections.Generic; namespace Demo { class Program {

  • C# MemoryStream类案例详解

    MemoryStream位于System.IO命名空间,为系统内存提供流式的读写操作.常作为其他流数据交换时的中间对象操作. MemoryStream类封装一个字节数组,在构造实例时可以使用一个字节数组作为参数,但是数组的长度无法调整.使用默认无参数构造函数创建实例,可以使用Write方法写入,随着字节数据的写入,数组的大小自动调整. 在对MemoryStream类中数据流进行读取时,可以使用seek方法定位读取器的当前的位置,可以通过指定长度的数组一次性读取指定长度的数据.ReadByte方法

  • C#的TimeSpan案例详解

    TimeSpan结构:表示一个时间间隔. 它含有以下四个构造函数: TimeSpan(Int64)将 TimeSpan结构的新实例初始化为指定的刻度数. (DateTime.Tick:是计算机的一个计时周期,单位是一百纳秒,即一千万分之一秒) TimeSpan(Int32, Int32, Int32)将 TimeSpan结构的新实例初始化为指定的小时数.分钟数和秒数. TimeSpan(Int32, Int32, Int32, Int32)将 TimeSpan结构的新实例初始化为指定的天数.小时

  • C#设计模式实现之生成器模式和责任链模式

    目录 生成器 设计类图: 实现代码: 优点: 用途与缺点: 责任链 设计类图: 实现代码: 优点: 用途和缺点: 总结 生成器 生成器模式:封装一个产品的构造过程,并允许按步骤构造. 现又一个度假计划指定,需要指定度假每一天的活动.旅馆.用餐.门票等等事情,但是每个客人的度假计划可能不太一样.例如天数.活动类型.用餐等等. 我们需要一个弹性的数据结构,代表客人的规划,以及不同的变化,也需要一系列潜在复杂顺序,创建这样的规划.如何提供一种方式来创建复杂的结构,也不会和创建它的步骤混在一起.迭代器的

  • Python的组合模式与责任链模式编程示例

    组合模式 我们把Composite模式看成一个复杂的属性结构,其实基本有三种角色:树干(定义一些操作树叶leaf的操作),树枝(树干上有很多树枝)和树叶(树干想要具体操作的对象) ,Composite模式帮我们实现:即它们在充当对象的时候,还是其他对象的容易,从而提供一致性 python的例子 class Trunk(object): '''树干''' def __str__(self): pass def subtree(self): pass class Composite(Trunk):

  • Android编程设计模式之责任链模式详解

    本文实例讲述了Android编程设计模式之责任链模式.分享给大家供大家参考,具体如下: 一.介绍 责任链模式(Iterator Pattern),是行为型设计模式之一.什么是"链"?我们将多个节点首尾相连所构成的模型称为链,比如生活中常见的锁链,就是由一个个圆角长方形的铁环串起来的结构.对于链式结构,每个节点都可以被拆开再连接,因此,链式结构也具有很好的灵活性.将这样一种结构应用于编程领域,将每一个节点看作是一个对象,每一个对象拥有不同的处理逻辑,将一个请求从链式的首端发出,沿着链的路

  • 23种设计模式(19)java责任链模式

    23种设计模式第十九篇:java责任链模式 定义:使多个对象都有机会处理请求,从而避免了请求的发送者和接收者之间的耦合关系.将这些对象连成一条链,并沿着这条链传递该请求,直到有对象处理它为止. 类型:行为类模式 类图: 首先来看一段代码: public void test(int i, Request request){ if(i==1){ Handler1.response(request); }else if(i == 2){ Handler2.response(request); }els

  • Java 设计模式之责任链模式及异步责任链详解

    目录 一.定义 二.普通责任链模式 三.异步责任链模式 一.定义 责任链模式(Chain of Responsibility Pattern):避免将一个请求的发送者与接受者耦合在一起,让多个对象都有机会处理请求.将接受请求的对象连接成一条链,并且沿着这条链传递请求,直到有一个对象能够处理它为止. 在很多源码都有涉及,如Mybatis拦截器.Filter- 责任链模式属于行为型模式. 二.普通责任链模式 抽象处理类:AbstractProcessor /** * 抽象处理类 */ public

  • Java设计模式之责任链模式的示例详解

    目录 应用场景 实际代码案例 无模式情况下的代码 采用责任链模式优化代码 采用建造者+责任链模式优化代码 责任链模式优缺点 责任链模式是将链中的每一个节点看做是一个对象,每个节点处理的请求均不相同,且内部自动维护下一个节点对象,当一个请求从链式的首段发出时,会沿着链的路径依次传递给每一个节点对象,直至有对象处理这个请求位置,属于行为模式. 这里需要注意的是每个节点都能对对象进行一定的处理(也可以不处理),处理完成之后节点再进行判断还要进行后续处理还是说传递给下一个节点. 应用场景 首先举一个日常

  • iOS应用设计模式开发中职责链(责任链)模式的实现解析

    定义 为了避免请求发送者与接收者耦合在一起,让多个对象都有可能接收请求,将这些对象连接成一条链,并且沿着这条链传递请求,直到有对象处理它为止,职责链模式又称为责任链模式,它是一种对象行为型模式.(如果你接触过异常处理,那么套用异常处理机制可以更好地理解). 职责链可以是一条直线,也可以是一个环,还可以是一个树形结构,不过最常见的职责链是直线型,即沿着一条单向的链来传递请求.链上的每一个对象都是请求处理者,职责链模式可以将请求的处理者组织成一条链,并使请求沿着链传递,由链上的处理者对请求进行相应的

  • Java责任链模式模板代码分享

    本文分享了一则Java编程责任链模式的模板代码,代码中有详细注释,大家可以参考.具体如下: //抽象处理者 public abstract class Handler{ private Handler nextHandler; //每个处理者都必须对请求做出处理 public final Response handleMessage(Request request){ Response response = null; //判断是否自己的处理级别 if(this.getHandlerLevel(

  • Java使用责任链模式处理学生请假问题详解

    本文实例讲述了Java使用责任链模式处理学生请假问题.分享给大家供大家参考,具体如下: 一. 模式定义 在责任链模式中,很多对象由每一个对象对其下家的引用而连接起来,形成一条链.客户端应用请求在这个链上进行传递,直到链上的某一个对象决定处理此请求.发出这个请求的客户端并不知道链上的哪个对象最终处理这个请求,这使系统可以在不影响客户端的情况下动态地重新组织链和分配责任. (1)抽象处理者角色:定义出一个处理请求的接口.如果需要,接口可以定义出一个方法,以设定和返回下家的引用.这个角色通常由一个Ja

  • 学习JavaScript设计模式之责任链模式

    一.定义 责任链模式:使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系,将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止. 二.示例 假设这么一个场景: 我们负责一个售卖手机的电商网站,经过分别缴纳500元定金和200元定金的两轮预定后,到了正式购买阶段.针对预定用户实行优惠,支付过500元定金的用户会收到100元的商城优惠券,支付过200元定金的用户会收到50元的商城优惠券,没有支付定金的用户归为普通购买,且在库存有限的情况下不一定保证买到. /*

随机推荐