设计者模式之建造者模式

简介: 设计者模式之建造者模式

建造者模式定义:使用多个简单的对象一步一步构建成一个复杂的对象。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。


主要意图:将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同的表示。


主要解决:主要解决在软件系统中,有时候面临着"一个复杂对象"的创建工作,其通常由各个部分的子对象用一定的算法构成;由于需求的变化,这个复杂对象的各个部分经常面临着剧烈的变化,但是将它们组合在一起的算法却相对稳定。


解决方案:将变与不变分离开。


优点:


1,建造者独立,容易扩展。


2,便于控制细节风险


缺点:


1,产品必须有共同点,范围有限制。


2,内部变化复杂,会有很多的建造类。


注意:建造者模式与工厂模式很像,但是建造者模式更加关注与零件装配的顺序,而工厂模式不是。


总结:


1,建造者模式和工厂模式,同属于类创建型模式,不同之处是建造者模式用来创建一个复杂的类,关注的是这个类的创建步骤,可以根据相同的步骤,最后创建出不同类的实例。而工厂模式只负责创建类,工厂模式中产出的是同一个产品。


2,建造这模式适用于创建复杂的对象,对象由多个部件构成,各部件面临着复杂的变化,但构件间的建造顺序是稳定的。


建造者模式类图:


代码实现:

using System;
using System.Collections;
using System.Collections.Generic;
namespace _05建造者模式_建造者模式基本
{
    class Program
    {
        static void Main(string[] args)
        {
            Director director = new Director();
            Builder b1 = new ConcreteBuilder1();
            Builder b2 = new ConcreteBuilder2();
            director.Construct(b1);
            Product p1 = b1.GetResult();
            p1.Show();
            director.Construct(b2);
            Product p2 = b2.GetResult();
            p2.Show();
            Console.Read();
        }
    }
    //类--产品类,由多个部件组成
    class Product
    {
        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);
            }
        }
    }
    //抽象建造者类
    abstract class Builder
    {
        public abstract void BuildPartA();
        public abstract void BuildPartB();
        public abstract Product GetResult();
    }
    //具体建造者类
    class ConcreteBuilder1 : Builder
    {
        private Product product = new Product();
        //建立部件A
        public override void BuildPartA()
        {
            product.Add("部件A");
        }
        //建立部件B
        public override void BuildPartB()
        {
            product.Add("部件B");
        }
        public override Product GetResult()
        {
            return product;
        }
    }
    //具体建造者类
    class ConcreteBuilder2 : Builder
    {
        private Product product = new Product();
        //建立部件X
        public override void BuildPartA()
        {
            product.Add("部件X");
        }
        //建立部件Y
        public override void BuildPartB()
        {
            product.Add("部件Y");
        }
        public override Product GetResult()
        {
            return product;
        }
    }
    //指挥类:主任
    class Director
    {
        public void Construct(Builder builder)
        {
            builder.BuildPartA();
            builder.BuildPartB();
        }
    }
}
相关文章
|
芯片
最详细STM32,cubeMX 按键点亮 led
最详细STM32,cubeMX 按键点亮 led
517 0
|
XML 监控 Java
JAVA日志技术 & Logback
为什么需要记录日志?我们不可能实时的24小时对系统进行人工监控,那么如果程序出现异常错误时要如何排查呢?并且系统在运行时做了哪些事情我们又从何得知呢?这个时候日志这个概念就出现了,日志的出现对系统监控和异常分析起着至关重要的作用。......
211 0
|
JavaScript Android开发
|
Linux 网络安全 数据安全/隐私保护
centos7常见操作
centos7常见操作
154 0
|
Java
java并发之同步辅助类CountDownLatch
CountDownLatch可以理解为一个计数器在初始化时设置初始值,当一个线程需要等待某些操作先完成时,需要调用await()方法。这个方法让线程进入休眠状态直到等待的所有线程都执行完成。每调用一次countDown()方法内部计数器减1,直到计数器为0时唤醒。这个可以理解为特殊的CyclicBarrier。线程同步点比较特殊,为内部计数器值为0时开始。
149 0
商家必收!天猫2018年春节发货规则公布
消费者在春节期间付款的订单,天猫商家需在2月27日24点前点击发货,并确保有物流状态纪录。
2231 0
|
3天前
|
弹性计算 运维 搜索推荐
三翼鸟携手阿里云ECS g9i:智慧家庭场景的效能革命与未来生活新范式
三翼鸟是海尔智家旗下全球首个智慧家庭场景品牌,致力于提供覆盖衣、食、住、娱的一站式全场景解决方案。截至2025年,服务近1亿家庭,连接设备超5000万台。面对高并发、低延迟与稳定性挑战,全面升级为阿里云ECS g9i实例,实现连接能力提升40%、故障率下降90%、响应速度提升至120ms以内,成本降低20%,推动智慧家庭体验全面跃迁。