设计模式——__构建者模式 Builder模式

来源:互联网 发布:搜索引擎自然排名算法 编辑:程序博客网 时间:2024/03/29 15:44


1、类图

指导者(Director):调用具体建造者角色以创建产品对象的各个部分。指导者并没有涉及具体产品类的信息,真正拥有具体产品的信息是具体建造者对象。它只负责保证对象各部分完整创建或按某种顺序创建。
抽象建造者角色(Builder):为创建一个Product对象的各个部件指定抽象接口,以规范产品对象的各个组成成分的建造。一般而言,此角色规定要实现复杂对象的哪些部分的创建,并不涉及具体的对象部件的创建。
具体建造者(ConcreteBuilder)
1)实现Builder的接口以构造和装配该产品的各个部件。即实现抽象建造者角色Builder的方法。
2)定义并明确它所创建的表示,即针对不同的商业逻辑,具体化复杂对象的各部分的创建
3)  提供一个检索产品的接口
4)   构造一个使用Builder接口的对象即在指导者的调用下创建产品实例


产品角色(Product):建造中的复杂对象。它要包含那些定义组件的类,包括将这些组件装配成产品的接口。


2、使用场景

2.1 点餐,套餐A有多个实物构成,这些实物共同构成套餐A,也就是产品

      

2.2 、在Effective Java第二版中,Josh Bloch在第二章中就提到使用Builder模式处理需要很多参数的构造函数。他不仅展示了Builder的使用,也描述了相这种方法相对使用带很多参数的构造函数带来的好处。在本文的结尾我将进一步总结Builde模式的优点。需要指出的是Josh Bloch已经在他的书本贯穿了这一思想。目前比较流行的链式调用,算是简化版的链式调用

public class Person{   private final String Name;   private final boolean isFemale;   public Person(      final String newName,      final boolean newIsFemale)   {      this.Name = newLastName;      this.isFemale = newIsFemale;   }}

public class PersonBuilder{   private String newName;   private boolean newIsFemale;    public PersonBuilder()   {   }    public PersonBuilder setNewLastName(String newName) {      this.newName = newName;      return this;   }     public PersonBuilder setNewIsFemale(boolean newIsFemale) {      this.newIsFemale = newIsFemale;      return this;   }    // 有些代码中喜欢用build,作为最后“产品”的统一出口   public Person createPerson() {      return new Person(newLastName, newFirstName, newMiddleName, newSalutation, newSuffix, newStreetAddress, newCity, newState, newIsFemale, newIsEmployed, newIsHomeOwner);   }}

3. 建造者模式的优点
       首先,建造者模式的封装性很好。使用建造者模式可以有效的封装变化,在使用建造者模式的场景中,一般产品类和建造者类是比较稳定的,因此,将主要的业务逻辑封装在导演类中对整体而言可以取得比较好的稳定性。
       其次,建造者模式很容易进行扩展。如果有新的需求,通过实现一个新的建造者类就可以完成,基本上不用修改之前已经测试通过的代码,因此也就不会对原有功能引入风险。


4. 建造者模式与工厂模式的区别
      我们可以看到,建造者模式与工厂模式是极为相似的,总体上,建造者模式仅仅只比工厂模式多了一个“导演类”的角色。在建造者模式的类图中,假如把这个导演类看做是最终调用的客户端,那么图中剩余的部分就可以看作是一个简单的工厂模式了。

      与工厂模式相比,建造者模式一般用来创建更为复杂的对象,因为对象的创建过程更为复杂(比如套餐A 多个产品构成),因此将对象的创建过程独立出来组成一个新的类——导演类。也就是说,工厂模式是将对象的全部创建过程封装在工厂类中,由工厂类向客户端提供最终的产品;而建造者模式中,建造者类一般只提供产品类中各个组件的建造,而将具体建造过程交付给导演类。由导演类负责将各个组件按照特定的规则组建为产品,然后将组建好的产品交付给客户端。

      建造者模式与工厂模式都是建造者模式,适用的场景也很相似。一般来说,如果产品的建造很复杂,那么请用工厂模式;如果产品的建造更复杂(产品多个组件构成时),那么请用建造者模式。

原创粉丝点击