BUILDER生成器——对象创建型模式

Builder模式是一种一步步创建一个复杂对象的设计模式,将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。主要在以下两个场景会使用Builder模式:

  1. 构建复杂对象,屏蔽内部构建细节。
  2. 解耦对象的构建过程和具体表示。

在这里插入图片描述

场景一:构建复杂对象,屏蔽内部构建细节

当一个类的成员变量很多,且可能有些成员变量不需要在对象初始化时初始化,那为了满足不同场景灵活地构造对象,就需要有很多重载的构造函数。这一方面会给用户造成困扰,不知道该选择哪一个构造函数;另一方面当构造函数中参数很多时,很容易发生变量错位的错误。Builder模式可以很清析地表示出设置对象各个参数的过程,因此,Builder模式通常与Composite模式共用。

Spark中SparkSession类就是使用了Builder模式,下面是SparkSession的部分源码。SparkSession典型的使用方式如下:SparkSession.builder().master("local").appName("test").config(conf).getOrCreate(),通过Builder模式将对象的一步步创建出来,并且不需要知道其为保证对象单例的构建细节。构建对象过程中每个参数的设置都非常清析,且Builer模式的方法都是可以链式调用,代码看起来非常简洁清析。

object SparkSession extends Logging {

  /**
   * Builder for [[SparkSession]].
   */
  class Builder extends Logging {
    private[spark] def sparkContext(sparkContext: SparkContext): Builder = synchronized {
      userSuppliedContext = Option(sparkContext)
      this
    }

    def appName(name: String): Builder = config("spark.app.name", name)

    def config(key: String, value: String): Builder = synchronized {
      options += key -> value
      this
    }

     def master(master: String): Builder = config("spark.master", 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值