定義:
將一個復(fù)雜對象的構(gòu)建與它的表示分離,使得同樣的構(gòu)建過程可以創(chuàng)建不同的表示吱窝。
UML類圖:
image.png
角色和職能:
- Builder(抽象建造類):為創(chuàng)建一個產(chǎn)品Product對象的各個部件指定抽象接口,在該接口中一般聲明兩類方法消恍,一類方法是build()惰匙,他們用于構(gòu)建復(fù)雜對象的各個部件;另一類方法是getResult()署恍,他們用于返回復(fù)雜對象。Builder可以是抽象類蜻直,也可以是接口盯质。
- ConcreteBuilder(具體建造類):實(shí)現(xiàn)了Builder接口,實(shí)現(xiàn)各個部件的具體構(gòu)造和裝配方法概而,定義并聲明他所創(chuàng)建的復(fù)雜對象呼巷,也可以提供一個方法返回創(chuàng)建好的復(fù)雜產(chǎn)品對象。
- Product(產(chǎn)品類):它是被構(gòu)建的復(fù)雜對象到腥,包含多個組成部件朵逝,具體建造者創(chuàng)建該產(chǎn)品的內(nèi)部表示并定義它的裝配過程。
- Director(指揮者類):
關(guān)于Director類
- 省略Director:
可以將Director與抽象建造者類進(jìn)行合并乡范,在Builder中提供逐步構(gòu)建復(fù)雜產(chǎn)品對象的construct方法配名。由于Builder類通常為抽象類,因此可以將construct方法定義為靜態(tài)方法晋辆。
abstract class ActorBuilder
{
protected static Actor actor = new Actor();
public abstract void buildType();
public abstract void buildSex();
public abstract void buildFace();
public abstract void buildCostume();
public abstract void buildHairstyle();
public static Actor construct(ActorBuilder ab)
{
ab.buildType();
ab.buildSex();
ab.buildFace();
ab.buildCostume();
ab.buildHairstyle();
return actor;
}
}
總結(jié)
-
主要優(yōu)點(diǎn):
- 在建造者模式中渠脉,客戶端不必知道產(chǎn)品內(nèi)部組成的細(xì)節(jié),將產(chǎn)品本身與產(chǎn)品的創(chuàng)建過程解 耦瓶佳,使得相同的創(chuàng)建過程可以創(chuàng)建不同的產(chǎn)品對象芋膘。
- 每一個具體建造者都相對獨(dú)立,而與其他的具體建造者無關(guān)霸饲,因此可以很方便地替換具體 建造者或增加新的具體建造者为朋,用戶使用不同的具體建造者即可得到不同的產(chǎn)品對象。由于 指揮者類針對抽象建造者編程厚脉,增加新的具體建造者無須修改原有類庫的代碼习寸,系統(tǒng)擴(kuò)展方 便,符合“開閉原則”
- 可以更加精細(xì)地控制產(chǎn)品的創(chuàng)建過程傻工。將復(fù)雜產(chǎn)品的創(chuàng)建步驟分解在不同的方法中霞溪,使得 創(chuàng)建過程更加清晰孵滞,也更方便使用程序來控制創(chuàng)建過程。
-
主要缺點(diǎn):
- 建造者模式所創(chuàng)建的產(chǎn)品一般具有較多的共同點(diǎn)鸯匹,其組成部分相似坊饶,如果產(chǎn)品之間的差異 性很大,例如很多組成部分都不相同殴蓬,不適合使用建造者模式匿级,因此其使用范圍受到一定的 限制。
- 如果產(chǎn)品的內(nèi)部變化復(fù)雜科雳,可能會導(dǎo)致需要定義很多具體建造者類來實(shí)現(xiàn)這種變化根蟹,導(dǎo)致 系統(tǒng)變得很龐大,增加系統(tǒng)的理解難度和運(yùn)行成本糟秘。
-
使用場景:
- 需要生成的產(chǎn)品對象有復(fù)雜的內(nèi)部結(jié)構(gòu),這些產(chǎn)品對象通常包含多個成員屬性球散。
- 需要生成的產(chǎn)品對象的屬性相互依賴尿赚,需要指定其生成順序。
- 對象的創(chuàng)建過程獨(dú)立于創(chuàng)建該對象的類蕉堰。在建造者模式中通過引入了指揮者類凌净,將創(chuàng)建過 程封裝在指揮者類中,而不在建造者類和客戶類中屋讶。
- 隔離復(fù)雜對象的創(chuàng)建和使用冰寻,并使得相同的創(chuàng)建過程可以創(chuàng)建不同的產(chǎn)品。