设计模式之Builder模式
前言
摸鱼摸到了设计模式,看了好几篇文章,跟进了一下mybatis源码里面的Builder设计模式,记录一下。
定义与构成
The intent of the Builder design pattern is to separate the construction of a complex object from its representation. By doing so the same construction process can create different representations.
将一个复杂对象的构建与其表示分离,使同样的构建过程可以创建不同的表示,模式包含Director、Builder、Product与ConcreteBuilder四个构成要素。具体的UML类图如下:
从类图分析模型元素的作用:
1、Product(产品): 产品接口或实现类,可能包含多个组成部件或复杂的参数逻辑,可能有若干个不同的产品对象。例如Product为汽车,可能有小汽车、电动车、重型卡车等多种车型ConcreteProduct,各自都有自己的发动机、油箱、轮胎等组成部件与组装逻辑。
2、Builder 抽象类(或使用接口定义):提供装配复杂产品Product的装配方法逻辑,必须包含一个返回Product实例的无参数方法build或getProduct,根据应用场景有不同的ConcreteBuilder实现。
3、ConcreteBuilder: Builder 的实现类或者Builder 的子类,实现 Builder 的抽象方法,编写此种 Builder 实现的方法。如Product汽车场景,可能有CarBuilder(小汽车)、TruckBuilder(卡车)、ElecCarBuilder(电动车)等具体实现。CarBuilder负责装配小汽车,TruckBuilder负责装配重型卡车。
4、Director: 决定如何使用 Builder 实现类提供的构建用方法。拥有一个负责组装的方法 void construct(Builder builder),在这个方法中通过组织并调用 builder 的方法,可以设置 builder。设置完成后,通过 builder 的构建方法 getProduct() 获得最终的产品。
使用场景
之前一个大佬同事给我们分享设计模式的时候说:平时可能都用过很多种设计模式,但是你自己都不知道你用到了设计模式。所以Builder设计模式平时使用还是比较普遍的。
这儿套用《shusheng007》这个大佬分享的Builder设计模式里面的使用场景:
当一个类的构造函数参数个数超过4个,而且这些参数有些是可选的参数,考虑使用构造者模式。
为什么使用Builder模式
当遇到多个Constructor构造器参数时可考虑用Builder模式。构造这个类的实例常见的三种方式:
1、重叠构造函数模式
这个我们经常见到也会经常使用,mybatis源码中的XMLConfigBuilder类中的示例:
public class XMLConfigBuilder extends BaseBuilder {
private boolean parsed;
private final XPathParser parser;
private String environment;
private final ReflectorFactory localReflectorFactory = new DefaultReflectorFactory();
public XMLConfigBuilder(Reader reader) {
this(reader, null, null);
}
public XMLConfigBuilder(Reader reader, String environment) {
this(reader, environment, null);
}
public XMLConfigB