zoukankan      html  css  js  c++  java
  • 【java_设计模式】建造者模式

    应用场景
    对生成对象进行链式配置
    好处:按需配置对象,灵活修改默认配置,比构造方法创建对象更直观。

    public static void init() {
    if (okHttpClient == null) {
    OkHttpClient.Builder builder = new OkHttpClient.Builder()
    .connectTimeout(5000, TimeUnit.MILLISECONDS)
    .connectTimeout(5000, TimeUnit.MILLISECONDS)
    .writeTimeout(5000, TimeUnit.MILLISECONDS);
    okHttpClient = builder.build();
    }
    }
    1
    2
    3
    4
    5
    6
    7
    8
    9
    实现过程
    1.创建目标对象Course
    2.创建目标对象的【建造者】内部类
    3.内部类拥有Course的同名成员变量,并提供build()方法返回Course对象,这里直接使用构造方法构造。


    // 内部类处理应用层传入的参数
    public static class CourseBuilder{
    private String courseName;
    private String coursePPT;

    // build()返回Course,用作链式调用的最后一步
    public Course build() {
    // 需要建立一个参数为CourseBudiler的构造方法
    return new Course(this);
    }

    //
    public CourseBuilder buildCourseName(String courseName) {
    this.courseName = courseName;
    return this;
    }

    public CourseBuilder buildCoursePPT(String coursePPT) {
    this.coursePPT = coursePPT;
    return this;
    }
    }
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    // 应用层.build()后调用该构造方法
    public Course(CourseBuilder courseBuilder) {
    this.courseName = courseBuilder.courseName;
    this.coursePPT = courseBuilder.coursePPT;
    }
    --------------------- 

  • 相关阅读:
    HTTP协议详解
    loadrunner性能测试步骤
    LR工作原理
    性能测试相关术语
    敏捷测试的方法和实践
    究竟什么是敏捷测试
    避免沙堆建楼 做好软件安全测试
    软件安全测试新武器 ——浅谈基于Dynamic Taint Propagation的测试技术
    软件安全测试的几个原则
    安全性测试--CSRF攻击
  • 原文地址:https://www.cnblogs.com/hyhy904/p/10935216.html
Copyright © 2011-2022 走看看