设计模式--建造者模式
简介
建造者模式是将一个复杂对象的构件过程与它的表示分离,使得同样的构建过程可以创建不同的表示,属于创建型模式。使用建造者模式对于用户而言只需要指定需要建造的类型就可以获得对象,建造过程及细节不需要了解。
建造者模式适用于创建对象需要很多步骤,但是步骤的顺序不一定固定。如果一个对象有非常复杂的内部结构(很多属性),可以将复杂对象的创建和使用进行分离。
类图:
建造者模式设计中主要有四个角色:
1、产品(Product):要创建的产品类对象。
2、建造者抽象(Builder):建造者的抽象类,规范产品对象的各个组成部分的建造,一般由子类实现具体的创建过程。
3、建造者(concreteBuilder):具体的Builder类,根据不同的业务逻辑,具体化对象的各个组成部分的创建。
4、调用者(Director):调用具体的创建者,来创建对象的各个部分,在指导者中不涉及具体产品的信息,只负责保证对象各部分完整创建或按某种顺序创建。
引用场景:
建造者适用于一个具有较多零件的复杂产品的创建过程,由于需求的变化,组成这个复杂产品的各个零件经常发生变化,但是他们的组合方式区相对稳定。
建造者模式适用于以下场景:
1、相同的方法,不同的执行顺序,产生不同的结果
2、多个部件或零件,都可以装配到一个对象中,但是产生的结果又不相同
3、产品类非常复杂,或者产品类中的调用顺序产生不同的作用。
4、当初始化一个对象特别复杂,参数多,而且很多参数都具有默认值时。
源码中的使用
1、JDK中的StringBuilder
,它提供的append()方法。
@Override
public StringBuilder append(String str) {
super.append(str);
return this;
}
2、在MyBatis
中的CacheBuilder
类
3、Spring中的BeanDefinitionBuilder
通过调用getBeanDefinition()
方法获取一个BeanDefinition
对象。
建造者模式的优缺点:
建造者模式的优点:
1、封装性好,创建和使用分离;
2、扩展性好,建造类之间独立、一定程度上解耦。
建造者模式的缺点:
1、产生多余的Builder对象;
2、产品内部发生变化,建造者都要修改,成本较大。
建造者模式和工厂模式的区别
1、建造者模式更加注重方法的调用顺序,工厂模式注重于创建对象。
2、创建对象的力度不同,建造者模式创建复杂的对象,由各种复杂的部件组成,工厂模式创建出来的都一样。
3、关注重点不一样,工厂模式只要把对象创建出来就可以,而建造者模式中不仅要创建出这个对象,还要知道这个对象由哪些部件组成。
4、建造者模式根据建造过程中的顺序不一样,最终的对象部件组成也不一样。