java建造者模式(Builder Pattern)详细解析及使用实例
时间:2018-09-20
本文章向大家介绍java建造者模式(Builder Pattern)详细解析及使用实例,需要的朋友可以参考一下
建造者模式
一、什么是建筑者模式?
建造者模式(Builder Pattern)使用多个简单的对象一步一步构建一个复杂的对象。
一个 Builder 类会一步一步构造最终的对象,该 Builder 类独立于其他对象。
建造者模式主要解决在软件系统中,有时候面临着"一个复杂对象"的创建工作,其通常由各个部分的子对象用一定的算法构成;由于需求的变化,这个复杂对象的各个部分经常面临着剧烈的变化,但是将它们组合在一起的算法却相对稳定。
二、建造者模式的具体实现
结构图
建造者模式中的四个角色:
- Builder:给出一个抽象接口,以规范产品对象的各个组成成分的建造。这个接口规定要实现复杂对象的哪些部分的创建,并不涉及具体的对象部件的创建。
- ConcreteBuilder:实现Builder接口,针对不同的商业逻辑,具体化复杂对象的各部分的创建。 在建造过程完成后,提供产品的实例。
- Director:调用具体建造者来创建复杂对象的各个部分,在指导者中不涉及具体产品的信息,只负责保证对象各部分完整创建或按某种顺序创建。
- Product:要创建的复杂对象。
java代码实现
1、创建人类实体类
package com.designpattern.builderPattern;
/**
* 对象 人
*
* @author zhongtao on 2018/9/17
*/
public class Human {
private String head;
private String body;
private String hand;
private String foot;
public String getHead() {
return head;
}
public void setHead(String head) {
this.head = head;
}
public String getBody() {
return body;
}
public void setBody(String body) {
this.body = body;
}
public String getHand() {
return hand;
}
public void setHand(String hand) {
this.hand = hand;
}
public String getFoot() {
return foot;
}
public void setFoot(String foot) {
this.foot = foot;
}
}
2、创建造人的 Builder 接口
package com.designpattern.builderPattern;
/**
* 造人接口 规定造人的规范 需要头、身体、手、脚
*
* @author zhongtao on 2018/9/17
*/
public interface BuilderHuman {
void buildHead();
void buildBody();
void buildHand();
void buildFoot();
/**
* 返回创建的对象
*/
Human createHuman();
}
3、ConcreteBuilder 创建不同类型的人
tallPerson
package com.designpattern.builderPattern;
/**
* 高个子的人
*
* @author zhongtao on 2018/9/17
*/
public class TallPersonBuilder implements BuilderHuman {
Human human;
public TallPersonBuilder() {
human = new Human();
}
@Override
public void buildHead() {
human.setHead("普通的头脑");
}
@Override
public void buildBody() {
human.setBody("壮实,高大的身体");
}
@Override
public void buildHand() {
human.setHand("长手");
}
@Override
public void buildFoot() {
human.setFoot("长脚");
}
@Override
public Human createHuman() {
return human;
}
}
smartHuman
package com.designpattern.builderPattern;
/**
* 聪明的人
*
* @author zhongtao on 2018/9/17
*/
public class SmartHumanBuilder implements BuilderHuman {
Human human;
public SmartHumanBuilder() {
human = new Human();
}
@Override
public void buildHead() {
human.setHead("高智商的头脑");
}
@Override
public void buildBody() {
human.setBody("健康的身体");
}
@Override
public void buildHand() {
human.setHand("普通的手");
}
@Override
public void buildFoot() {
human.setFoot("普通的脚");
}
@Override
public Human createHuman() {
return human;
}
}
4、Director 建造者模式的核心 调用具体建造者来创建不同的人
package com.designpattern.builderPattern;
/**
* 管理造人的顺序 BuilderHuman不同,则创建的人不同
* @author zhongtao on 2018/9/17
*/
public class HumanDirector {
public Human createHumanByDirector(BuilderHuman builderHuman){
builderHuman.buildHead();
builderHuman.buildBody();
builderHuman.buildHand();
builderHuman.buildFoot();
return builderHuman.createHuman();
}
}
5、建造者模式测试
package com.designpattern.builderPattern;
import org.junit.Test;
/**
* 测试
*
* @author zhongtao on 2018/9/17
*/
public class BuilderPatternTest {
/**
* 测试建造者模式
*/
@Test
public void test() {
HumanDirector humanDirector = new HumanDirector();
//创建高个子的人
Human humanByDirector = humanDirector.createHumanByDirector(new TallPersonBuilder());
System.out.println(humanByDirector.getHead());
System.out.println(humanByDirector.getBody());
System.out.println(humanByDirector.getHand());
System.out.println(humanByDirector.getFoot());
System.out.println("------简单的分割线------");
//创建聪明的人
Human smartHuman = humanDirector.createHumanByDirector(new SmartHumanBuilder());
System.out.println(smartHuman.getHead());
System.out.println(smartHuman.getBody());
System.out.println(smartHuman.getHand());
System.out.println(smartHuman.getFoot());
}
}
三、建造者模式的优缺点
优点:
- 建造者独立,易扩展。
- 便于控制细节风险。
缺点:
- 产品必须有共同点,范围有限制。
- 如内部变化复杂,会有很多的建造类。
注意事项:
与工厂模式的区别,建造者模式更加关注与零件装配的顺序。
- 2017.11.7解题报告
- TensorFlow从0到1 - 11 - 74行Python实现手写体数字识别
- 让priority_queue支持小根堆的几种方法
- 一招解决4道leetcode hard题,动态规划在字符串匹配问题中的应用
- 细数Python中的数据类型以及他们的方法
- 洛谷 P3807 【模板】卢卡斯定理
- 数据城堡参赛代码实战篇(六)---使用sklearn进行数据标准化及参数寻优
- 震惊!Vector两行代码求逆序对,六行代码过普通平衡树
- 数据城堡参赛代码实战篇(五)---使用sklearn解决分类问题
- 洛谷P1894 [USACO4.2]完美的牛栏The Perfect Stall
- [编程经验]Python生成器、迭代器与yield语句小结
- TensorFlow从0到1 - 12 - TensorFlow构建3层NN玩转MNIST
- 数据城堡参赛代码实战篇(四)---使用pandas合并数据表
- HDU 2586 How far away ?
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- 在tensorflow下利用plt画论文中loss,acc等曲线图实例
- PHP生成短网址的思路以及实现方法的详解
- ThinkPHP 3.2.3实现加减乘除图片验证码
- Python数据相关系数矩阵和热力图轻松实现教程
- PHP中md5()函数的用法讲解
- thinkPHP框架实现的简单计算器示例
- Keras在训练期间可视化训练误差和测试误差实例
- Laravel如何自定义command命令浅析
- wordpress自定义标签云与随机获取标签的方法详解
- 使用Keras画神经网络准确性图教程
- PHP序列化的四种实现方法与横向对比
- PHP自动载入类文件函数__autoload的使用方法
- 安装python3.7编译器后如何正确安装opnecv的方法详解
- python数据类型强制转换实例详解
- PHP使用OB缓存实现静态化功能示例