C#设计模式——建造者模式
建造者模式:
一、定义:
将一个复杂对象的构建与他的表示分离,使得同样的构建过程可以创建不同的表示。
二、使用条件:内部构建间的建造顺序通常稳定,但对象内部构建通常面临着复杂的变化。意思就比如建造小人,建造小人都是先头后身体,再左右臂最后是腿脚,这个建造顺序是稳定的,但具体小人的外貌如何,体型如何性别如何都是不定的,复杂变化着的,具体建造什么样的小人,这就需要有个指挥者Director。
三、了解优缺点:
该模式使得建造代码与表示代码分离,由于建造者隐藏了产品是如何组装的,所以若需要改变一个产品内部的表示,只需要再定义一个具体的建造者就可以了。
四、应用:
1、建造者模式结构图:
2、代码展示:
<span style="font-size:18px;"> <span style="white-space:pre"> </span>/// <summary>
<span style="white-space:pre"> </span>/// Product类——产品类,由多个部件组成
<span style="white-space:pre"> </span>/// </summary>
<span style="white-space:pre"> </span>class Product
<span style="white-space:pre"> </span>{
IList<string> parts = new List<string>();
public void Add(string part)
{
parts.Add(part);
}
public void Show()
{
Console.WriteLine("\n产品 创建---");
foreach (string part in parts)
{
Console.WriteLine(part);
}
}
/// <summary>
/// Builder类——抽象建造者类,确定产品由两个部件PartA和PartB组成,并声明一个得到产品建造后结果的办法GetResult
/// </summary>
abstract class Builder
{
public abstract void BuildPartA();
public abstract void BuildPartB();
public abstract Product GetResult();
}
/// <summary>
/// ConcreteBuilder1类——具体建造者类
/// </summary>
class ConcreteBuilder1 : Builder
{
private Product product = new Product();
public override void BuildPartA()
{
product.Add("部件A");
}
public override void BuildPartB()
{
product.Add("部件B");
}
public override Product GetResult()
{
return product;
}
}
/// <summary>
/// ConcreteBuilder2类——具体建造者类
/// </summary>
class ConcreteBuilder2 : Builder
{
private Product product = new Product();
public override void BuildPartA()
{
product.Add("部件X");
}
public override void BuildPartB()
{
product.Add("部件Y");
}
public override Product GetResult()
{
return product;
}
}
/// <summary>
/// Director类——指挥者类 指挥建造过程
/// </summary>
class Director
{
public void Construct(Builder builder)
{
builder.BuildPartA();
builder.BuildPartB();
}
}
//客户端调用:
static void Main(string[] args)
{
Director director = new Director();
Builder b1 = new ConcreteBuilder1();
Builder b2 = new ConcreteBuilder2();
///指挥者用ConcreteBuilder1的方法来建造产品
director.Construct(b1);
Product p1 = b1.GetResult();
p1.Show();
director.Construct(b2);
Product p2 = b2.GetResult();
p2.Show();
Console.Read();
} </span>
3、适用场景:
在当创建复杂对象的算法应该独立于该对象的组成部分以及他们的装配方式时适用的模式。
五、总结:
建造者模式使建造代码与表示分离,使得同样的构建过程可以创建不同的表示。用户只需指定需要建造的类型就可以得到产品,具体建造的过程和细节不需知道。对象内部构建间的建造顺序稳定。
还没有评论,来说两句吧...