Builder模式是一种一步步创建一个复杂对象的设计模式,将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。主要在以下两个场景会使用Builder模式:
- 构建复杂对象,屏蔽内部构建细节。
- 解耦对象的构建过程和具体表示。
场景一:构建复杂对象,屏蔽内部构建细节
当一个类的成员变量很多,且可能有些成员变量不需要在对象初始化时初始化,那为了满足不同场景灵活地构造对象,就需要有很多重载的构造函数。这一方面会给用户造成困扰,不知道该选择哪一个构造函数;另一方面当构造函数中参数很多时,很容易发生变量错位的错误。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",