C#设计模式(5)——建造者模式
1.建造者模式介绍
在软件开发中,有时我们要创建一个复杂的对象,这个对象由几个子部件按一定的步骤组合而成,这时候我们就可以使用建造者模式了。说到建造者我们首先想到的是盖房子,盖房子简单的说有三个步骤:打地基,砌砖,粉刷。我们就以盖房子为例解释建造者模式的用法。
建造者模式有三个角色:建造者,具体的建造者,监工。理清这三个角色的作用我们就可以愉快的使用建造者模式了。
建造者:一般为抽象类或接口,定义了建造者的功能。如盖房子例子的建造者有打地基,砌砖和粉刷的功能。
具体的建造者:实现了建造者的抽象方法(或接口)。不同的具体建造者生产的组件不同,如一个技术好的建造者打地基深,砌砖整齐,粉刷光滑,而技术差的建造者打地基浅,砌砖错乱,粉刷粗糙。
监工:制定建造的算法。建造者可以打地基,砌砖,粉刷,但是不知道先粉刷还是先打地基,监工就是给建造者制定盖房子步骤的。
代码实现如下,
建造者和具体建造者:
//建造者抽象类,定义了建造者的能力
public abstract class Builder
{
public abstract void Dadiji();//打地基
public abstract void QiZhuan();//砌砖
public abstract void FenShua();//粉刷
} /// <summary>
/// 技术好的建造者
/// </summary>
public class GoodBuilder : Builder
{
private StringBuilder house = new StringBuilder();
public override void Dadiji()
{
house.Append("深地基-->");
//这里一般是new一个部件,添加到实例中,如 house.Diji=new Diji("深地基")
//为了演示方便 用sringBuilder表示一个复杂的房子,string表示房子的部件
} public override void FenShua()
{
house.Append("粉刷光滑-->");
} public override void QiZhuan()
{
house.Append("砌砖整齐-->");
}
public string GetHouse()
{
return house.Append("好质量房子建成了!").ToString();
}
} /// <summary>
/// 技术差的建造者
/// </summary>
public class BadBuilder:Builder
{
private StringBuilder house = new StringBuilder();
public override void Dadiji()
{
house.Append("挖浅地基-->");
} public override void FenShua()
{
house.Append("粉刷粗糙-->");
} public override void QiZhuan()
{
house.Append("砌砖错乱-->");
}
public string GetHouse()
{
return house.Append("坏质量房子建成了!").ToString();
}
}
监工:
//监工类,制定盖房子的步骤
public class Director
{
private Builder builder;
public Director(Builder builder)
{
this.builder = builder;
} //制定盖房子的流程,
public void Construct()
{
builder.Dadiji();//先打地基
builder.QiZhuan();//再砌砖
builder.FenShua();//最后粉刷
}
}
客户端调用:
class Program
{
static void Main(string[] args)
{
//监工1派遣技术好的建造者盖房子
GoodBuilder goodBuilder = new GoodBuilder();
Director director1 = new Director(goodBuilder);
director1.Construct();
string house1 = goodBuilder.GetHouse();
Console.WriteLine(house1); //监工2派遣技术差的建造者盖房子
GoodBuilder badBuilder = new GoodBuilder();
Director director2 = new Director(goodBuilder);
director2.Construct();
string house2 = goodBuilder.GetHouse();
Console.WriteLine(house2);
Console.ReadKey();
}
}
运行结果:
2.小结
上边例子的类图
建造者模式的使用场景:
主要解决在软件系统中,有时候面临着"一个复杂对象"的创建工作,其通常由各个部分的子对象用一定的算法构成;由于需求的变化,这个复杂对象的各个部分经常面临着剧烈的变化,但是将它们组合在一起的算法却相对稳定,这时适合用建造者模式。StringBuilder和Quartz中的JobBuilder,TriggerBuilder都使用了建造者模式。如果每添加一个部件都返回建造对象的索引,那么我们就可以实现基本的链式构造,如JobBuilder和TriggerBuilder都可以通过Fluent interface形式进行构造。
建造者模式的优点:
1.实例的构建具体到组件层次,方便控制细节;
2.具体的建造者相互独立,易于扩展。
建造者模式的缺点:
当组件的组合种类很多时,需要创建很多的具体建造者类。
C#设计模式(5)——建造者模式的更多相关文章
- Java设计模式之建造者模式(Builder)
前言: 最近一直在学习okHttp,也对其做了一些整理,okHttp和Retrofit结合大大加速我们的开发效率,源码里面采用了很多设计模式,今天我们来学习一下其中的设计模式之一建造者模式. 建造者模 ...
- C#设计模式(5)——建造者模式(Builder Pattern)
一.引言 在软件系统中,有时需要创建一个复杂对象,并且这个复杂对象由其各部分子对象通过一定的步骤组合而成.例如一个采购系统中,如果需要采购员去采购一批电脑时,在这个实际需求中,电脑就是一个复杂的对象, ...
- 【GOF23设计模式】建造者模式
来源:http://www.bjsxt.com/ 一.[GOF23设计模式]建造者模式详解类图关系 建造飞船 package com.test.Builder; public class AirShi ...
- C++设计模式之建造者模式(三)
4.引入钩子方法的建造者模式 建造者模式除了逐步构建一个复杂产品对象外.还能够通过Director类来更加精细地控制产品的创建过程.比如添加一类称之为钩子方法(HookMethod)的特殊方法来控制是 ...
- 乐在其中设计模式(C#) - 建造者模式(Builder Pattern)
原文:乐在其中设计模式(C#) - 建造者模式(Builder Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 建造者模式(Builder Pattern) 作者:webabc ...
- 折腾Java设计模式之建造者模式
博文原址:折腾Java设计模式之建造者模式 建造者模式 Separate the construction of a complex object from its representation, a ...
- C#设计模式之四建造者模式(Builder Pattern)【创建型】
一.引言 今天我们要讲讲Builder模式,也就是建造者模式,当然也有叫生成器模式的,英文名称是Builder Pattern.在现实生活中,我们经常会遇到一些构成比较复杂的物品,比如:电脑,它就是一 ...
- Java 设计模式之建造者模式(四)
原文地址:Java 设计模式之建造者模式(四) 博客地址:http://www.extlight.com 一.前言 今天继续介绍 Java 设计模式中的创建型模式--建造者模式.上篇设计模式的主题为 ...
- GOF23设计模式之建造者模式
GOF23设计模式之建造者模式 场景: 我们要建造一个复杂的产品.比如:神州飞船,Iphone.这个复杂的产品的创建.有这样的一个问题需要处理: 装配这些子组件是不是有个步骤问题? 实际开发中,我们所 ...
- java设计模式3——建造者模式
java设计模式3--建造者模式 1.建造者模式介绍: 建造者模式属于创建型模式,他提供了一种创建对象得最佳方式 定义: 将一个复杂对象的构建和与它的表示分离,使得同样的构建过程可以创建不同的表示 主 ...
随机推荐
- Cetos 中添加bbr服务
说明:此方法只适用于KVM架构的,OpenVZ平台无法使用: 一:安装bbr服务: # wget --no-check-certificate https://github.com/teddysun/ ...
- Codeforces543 B. Destroying Roads
传送门:>Here< 题意:给出一张无向图(边权为1),并给出两对起点和终点以及距离:s1,t1,l1; s2,t2,l2; 要求删除尽量多的边,使得dis(s1,t1)<=l1, ...
- 【XSY1905】【XSY2761】新访问计划 二分 树型DP
题目描述 给你一棵树,你要从\(1\)号点出发,经过这棵树的每条边至少一次,最后回到\(1\)号点,经过一条边要花费\(w_i\)的时间. 你还可以乘车,从一个点取另一个点,需要花费\(c\)的时间. ...
- 【CF768G】The Winds of Winter 可持久化线段树 DFS序
题目大意 给定一棵\(n\)个点的树,对于树上每个结点,将它删去,然后可以将得到的森林中任意一个点与其父亲断开并连接到另一颗树上,对每一个点求出森林中所有树\(size\)最大值的最小值. \(n\l ...
- ios-deploy was not found
Ionic 打包ios的时候,突然报错,提示如下: (node:1157) UnhandledPromiseRejectionWarning: ios-deploy was not found. Pl ...
- 【CodeForces 717C】Potions Homework
BUPT 2017 summer training (for 16) #1G 题意 每个人有一个懒惰值,每个任务有个难度,一开始每个人的任务和懒惰值都为\(a_i\),完成任务时间是懒惰值乘以难度,现 ...
- 洛谷P4581 [BJOI2014]想法(玄学算法,拓扑排序)
洛谷题目传送门 萝卜大毒瘤 题意可以简化成这样:给一个DAG,求每个点能够从多少个入度为\(0\)的点到达(记为\(k\)). 一个随机做法:给每个入度为\(0\)的点随机一个权值,在DAG上求出每个 ...
- 【BZOJ4008】[HNOI2015]亚瑟王(动态规划)
[BZOJ4008][HNOI2015]亚瑟王(动态规划) 题面 BZOJ 洛谷 题解 设\(f[i][j]\)表示前\(i\)张卡中有\(j\)张被触发的概率. 分两种情况转移,即当前这张是否被触发 ...
- 【dp】P1434 [SHOI2002]滑雪
题目描述 Michael喜欢滑雪.这并不奇怪,因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你.Michael想知道在一个区域中最长 ...
- 20165223 《JAVA程序设计》第六周学习总结
教材学习内容总结 第八章-常用实用类-要点 基础:String类 重点:StringTokenizer类,Scanner类 难点:Class类与Console类,Pattern类与Match类 其他特 ...