一、建造者模式
将一个复杂对象的构建和它的表示分离,使得同样的构建过程可以创建不同的表示。
下面以生产汽车为例子:
建造的复杂对象Car,提供基本方法。
public class Car {
private String chassis; //汽车底盘
private String tyre; //汽车轮胎
private String steeringWheel; //汽车方向盘
public String getChassis() {
return chassis;
}
public void setChassis(String chassis) {
this.chassis = chassis;
}
public String getTyre() {
return tyre;
}
public void setTyre(String tyre) {
this.tyre = tyre;
}
public String getSteeringWheel() {
return steeringWheel;
}
public void setSteeringWheel(String steeringWheel) {
this.steeringWheel = steeringWheel;
}
}
抽象的建造者接口,主要是实现所有声明的方法以及返回建造好的产品实例。
public interface CarBuilder {
public void createChassis();
public void createTyre();
public void createsSteeringWheel();
public Car builder();
}
具体建造者实现了抽象建造者接口,主要是实现所有声明的方法以及返回建造好的产品实例。
public class SagitarCarBuilder implements CarBuilder{
private Car car=new Car();
public void createChassis() {
car.setChassis("速腾的底盘,嗷嗷叫,断轴很牛逼!");
}
public void createTyre() {
car.setTyre("固特异的轮胎,还可以");
}
public void createsSteeringWheel() {
car.setSteeringWheel("真皮方向盘!就问你牛逼不?");
}
public Car builder() {
return car;
}
}
负责调用具体建造者按照顺序建造产品。导演者只负责调度,真正执行的是具体建造者角色。
public class CarDirector {
private CarBuilder carBuilder;
public CarDirector(CarBuilder carBuilder){
this.carBuilder = carBuilder;
}
public Car construct(){
carBuilder.createChassis();
carBuilder.createTyre();
carBuilder.createsSteeringWheel();
return carBuilder.builder();
}
}
二、建造者模式的优缺点
优点
1)降低代码耦合度。在建造者模式中,客户端不需要知道产品内部是如何实现的,我们只需得到产品的对象。并且使用导演者和建造者分离组装过程和组件具体构造过程,具有灵活的扩展性。
2)优秀的扩展性。具体建造者相互独立,方便扩展,符合开闭原则。
缺点
1)一定的使用范围限制。建造者模式的产品的组件基本相同,如果产品的差异性较大,建造者模式就不适用了。
三、比较
跟工厂方法模式对比:建造者模式和工厂模式同样是创建一个产品,工厂模式就是一个方法,而建造者模式有多个方法,并且建造者模式是有顺序的执行方法。就是说建造者模式强调的是顺序,而工厂模式没有顺序一说。