java实现建造者模式(Builder Pattern)

 更新时间:2021年10月12日 14:15:33   作者:ZT1994  
这篇文章主要为大家详细介绍了java实现建造者模式Builder Pattern,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

一、什么是建筑者模式?

  建造者模式(Builder Pattern)使用多个简单的对象一步一步构建一个复杂的对象。

  一个 Builder 类会一步一步构造最终的对象,该 Builder 类独立于其他对象。

  建造者模式主要解决在软件系统中,有时候面临着"一个复杂对象"的创建工作,其通常由各个部分的子对象用一定的算法构成;由于需求的变化,这个复杂对象的各个部分经常面临着剧烈的变化,但是将它们组合在一起的算法却相对稳定。

二、建造者模式的具体实现

结构图

建造者模式中的四个角色:

1、Builder:给出一个抽象接口,以规范产品对象的各个组成成分的建造。这个接口规定要实现复杂对象的哪些部分的创建,并不涉及具体的对象部件的创建。
2、ConcreteBuilder:实现Builder接口,针对不同的商业逻辑,具体化复杂对象的各部分的创建。 在建造过程完成后,提供产品的实例。
3、Director:调用具体建造者来创建复杂对象的各个部分,在指导者中不涉及具体产品的信息,只负责保证对象各部分完整创建或按某种顺序创建。
4、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());
  }
}

三、建造者模式的优缺点

优点:

建造者独立,易扩展。
便于控制细节风险。

缺点:

产品必须有共同点,范围有限制。
如内部变化复杂,会有很多的建造类。

注意事项:

与工厂模式的区别,建造者模式更加关注与零件装配的顺序。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • SpringBoot使用Redis对用户IP进行接口限流的示例详解

    SpringBoot使用Redis对用户IP进行接口限流的示例详解

    使用接口限流的主要目的在于提高系统的稳定性,防止接口被恶意打击,这篇文章主要介绍了SpringBoot使用Redis对用户IP进行接口限流的示例代码,需要的朋友可以参考下
    2023-07-07
  • SpringBoot 如何读取pom.xml中的值

    SpringBoot 如何读取pom.xml中的值

    这篇文章主要介绍了SpringBoot 如何读取pom.xml中的值,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • SpringBoot+MyBatisPlus+Vue 前后端分离项目快速搭建过程(前端篇)

    SpringBoot+MyBatisPlus+Vue 前后端分离项目快速搭建过程(前端篇)

    这篇文章主要介绍了SpringBoot+MyBatisPlus+Vue 前后端分离项目快速搭建过程(前端篇),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-05-05
  • 如何基于SpringSecurity的@PreAuthorize实现自定义权限校验方法

    如何基于SpringSecurity的@PreAuthorize实现自定义权限校验方法

    spring Security提供有若干个过滤器,它们能够拦截Servlet请求,并将这些请求转给认证和访问决策管理器处理,从而增强安全性,下面这篇文章主要给大家介绍了关于如何基于SpringSecurity的@PreAuthorize实现自定义权限校验方法的相关资料,需要的朋友可以参考下
    2023-03-03
  • java并发访问重复请求过滤问题

    java并发访问重复请求过滤问题

    本篇文章给大家分享了关于java并发访问重复请求过滤的相关问题以及解决方法,对此有需要的朋友参考学习下。
    2018-05-05
  • Mybatis的Dao层实现原理分析

    Mybatis的Dao层实现原理分析

    这篇文章主要介绍了Mybatis的Dao层实现原理分析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • Spring源码如何修改Bean的属性用到的相关类

    Spring源码如何修改Bean的属性用到的相关类

    这篇文章主要介绍了Spring源码如何修改Bean的属性用到的相关类,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • LinkedBlockingQueue链式阻塞队列的使用和原理解析

    LinkedBlockingQueue链式阻塞队列的使用和原理解析

    这篇文章主要介绍了LinkedBlockingQueue链式阻塞队列的使用和原理解析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • mybatis多数据源动态切换的完整步骤

    mybatis多数据源动态切换的完整步骤

    这篇文章主要给大家介绍了关于mybatis多数据源动态切换的完整步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • 关于SpringBoot中的XA事务详解

    关于SpringBoot中的XA事务详解

    这篇文章主要介绍了关于SpringBoot中的XA事务详解,事务管理可以确保数据的一致性和完整性,同时也可以避免数据丢失和冲突等问题。在分布式环境中,XA 事务是一种常用的事务管理方式,需要的朋友可以参考下
    2023-07-07

最新评论