什么叫建造者模式?
当我们创建一个复杂对象时,可能大家的第一反应就是使用工厂模式。但是如果构建一个对象非常复杂,而且有些比如说属性之类的是可选的,而且需要支持我们自己随意的动态搭配,那么这时候如果要用工厂设计模式就不太好实现了,所以这就需要配合我们的建造者模式来实现。
建造者模式(Builder Pattern)是将一个复杂的对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。
建造者模式属于创建型模式,对使用者而言,只需要指定需要建造的类型就可以获得对象,建造过程和细节不需要了解。
建造者模式的组成
产品类
需要生产的具体的产品,这个产品往往比较复杂,里面会有很多属性,或者特性。例如:电脑这个产品,有组件鼠标,显示屏,键盘组成。但是每个组件的构造很复杂,我们不会生产,但是我们知道可以将这三个部分组装成一个电脑。
抽象构造类
抽象出各个组件的生产方法。比如生产鼠标的工艺,生产屏幕的工艺,生产键盘的工艺。
具体构造类
工艺有了,需要构造类的代工方法去加工生成,比如有windows和macOs两家生产。
指挥者类
指挥具体的电脑如何组装。也就是产生最后的产品,电脑这个对象。
类图
![](https://img.haomeiwen.com/i20347625/900963281c7329e0.png)
代码
产品类
package design_model.builder;
/**
* @Description: 产品类
*/
public class Computer {
/**
* 鼠标
*/
private String mouse;
/**
* 显示器
*/
private String screen;
/**
* 键盘
*/
private String keyBoard;
public String getMouse() {
return mouse;
}
public void setMouse(String mouse) {
this.mouse = mouse;
}
public String getScreen() {
return screen;
}
public void setScreen(String screen) {
this.screen = screen;
}
public String getKeyBoard() {
return keyBoard;
}
public void setKeyBoard(String keyBoard) {
this.keyBoard = keyBoard;
}
@Override
public String toString() {
return "Computer{" +
"mouse='" + mouse + '\'' +
", screen='" + screen + '\'' +
", keyBoard='" + keyBoard + '\'' +
'}';
}
}
抽象构造类
package design_model.builder;
/**
* @Description: 抽象建造者
*/
public abstract class AbstractBuilder {
protected Computer computer = new Computer();
/**
* 构建鼠标
*/
public abstract void buildMouse();
/**
* 构建屏幕
*/
public abstract void buildScreen();
/**
* 构建键盘
*/
public abstract void buildKeyBoard();
/**
*
* @return
*/
public Computer builderComputer(){
return computer;
}
}
具体构造类
windows构造类
package design_model.builder;
/**
* @Description:windows构造类
*/
public class WindowsComputerBuilder extends AbstractBuilder{
@Override
public void buildMouse() {
super.computer.setMouse("Windows的鼠标");
}
@Override
public void buildScreen() {
super.computer.setScreen("Windows的屏幕");
}
@Override
public void buildKeyBoard() {
super.computer.setKeyBoard("Windows的键盘");
}
}
macOs构造类
package design_model.builder;
/**
* @Description:macOs构造类
*/
public class MacOsComputerBuilder extends AbstractBuilder{
@Override
public void buildMouse() {
super.computer.setMouse("MacOs的鼠标");
}
@Override
public void buildScreen() {
super.computer.setScreen("MacOs的屏幕");
}
@Override
public void buildKeyBoard() {
super.computer.setKeyBoard("MacOs的键盘");
}
}
指挥者类
package design_model.builder;
/**
* @Description: 指挥者
*/
public class Constructor {
private AbstractBuilder abstractBuilder;
public Constructor(AbstractBuilder abstractBuilder) {
this.abstractBuilder = abstractBuilder;
}
/**
* 具体建造方法
* @return
*/
public Computer builder(){
abstractBuilder.buildMouse();
abstractBuilder.buildScreen();
abstractBuilder.buildKeyBoard();
return abstractBuilder.builderComputer();
}
}
测试类测试
package design_model.builder;
/**
* @Description: 测试类
*/
public class Client {
public static void main(String[] args) {
MacOsComputerBuilder macOsComputerBuilder = new MacOsComputerBuilder();
Constructor constructor = new Constructor(macOsComputerBuilder);
Computer computer = constructor.builder();
System.out.println(computer);
}
}
结果
/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/bin/java -javaagent:/Applications/IntelliJ IDEA.app/Contents/lib/idea_rt.jar=64850:/Applications/IntelliJ IDEA.app/Contents/bin -Dfile.encoding=UTF-8 -classpath /Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/charsets.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/deploy.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/ext/cldrdata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/ext/jaccess.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/ext/jfxrt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/ext/localedata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/ext/nashorn.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/ext/sunec.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/ext/zipfs.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/javaws.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/jce.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/jfr.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/jfxswt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/jsse.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/management-agent.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/plugin.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/resources.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/jre/lib/rt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/lib/ant-javafx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/lib/dt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/lib/javafx-mx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/lib/jconsole.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/lib/packager.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/lib/sa-jdi.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_291.jdk/Contents/Home/lib/tools.jar:/Users/duiba/IdeaProjects/demo/out/production/demo design_model.builder.Client
Computer{mouse='MacOs的鼠标', screen='MacOs的屏幕', keyBoard='MacOs的键盘'}
Process finished with exit code 0
思考
建造者模式与工厂模式的区别
工厂模式和建造者模式都是生产一个对象实例出来。
工厂模式一般都是创建一个产品,注重的是把这个产品创建出来就行,只要创建出来,不关心这个 产品的组成部分。从代码上看,工厂模式就是一个方法,用这个方法就能生产出产品。
建造者模式也是创建一个产品,但是不仅要把这个产品创建出来,还要关系这个产品的组成细节, 组成过程。从代码上看,建造者模式在建造产品时,这个产品有很多方法,建造者模式会根据这些相同 方法但是不同执行顺序建造出不同组成细节的产品。
网友评论