您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“java如何實現(xiàn)生成器模式”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“java如何實現(xiàn)生成器模式”這篇文章吧。
定義:
將一個復雜對象的構(gòu)建與它的表示分離,使得同樣的構(gòu)建過程可以創(chuàng)建不同的表示。生成器模式利用一個導演者對象和具體建造者對象一個一個地建造出所有的零件,從而建造出完整的對象。
四個要素:
Builder:生成器接口,定義創(chuàng)建一個Product對象所需要的各個部件的操作。
ConcreteBuilder:具體的生成器實現(xiàn),實現(xiàn)各個部件的創(chuàng)建,并負責組裝Product對象的各個部件,同時還提供一個讓用戶獲取組裝完成后的產(chǎn)品對象的方法。
Director:指導者,也被稱導向者,主要用來使用Builder接口,以一個統(tǒng)一的過程來構(gòu)建所需要的Product對象。
Product:產(chǎn)品,表示被生成器構(gòu)建的復雜對象,包含多個部件。
示例:
網(wǎng)上有用KFC的例子來描述生成器模式,比較通俗易懂。
假設KFC推出兩種套餐:奧爾良雞腿堡套餐和香辣雞腿堡套餐。
奧爾良套餐包括:一個奧爾良雞腿堡、一個炸雞翅、一杯雪碧。
雞腿堡套餐包括:一個香辣雞腿堡、一份薯條、一杯可樂。
每份套餐都是:主食、副食、飲料。
KFC服務員要根據(jù)顧客的要求來提供套餐,那這個需求里面什么是固定的,什么是變化的呢?很明顯顧客都是要的套餐,顧客的目的是一樣的。 套餐里面都是主食、副食、飲料,這也是固定的。至于主食是什么、副食是什么、飲料是什么,這個是變化的。
在實際的軟件開發(fā)過程中,有時候面臨著“一個復雜對象”的創(chuàng)建工作,其通常由各個部分的子對象采用一定的組合構(gòu)成,由于需求的變化,這個復雜對象的各個部分或者其子對象經(jīng)常要變化(例如,雞腿堡套餐的顧客不喜歡可樂,要換奶茶),但是他們的結(jié)構(gòu)卻相對穩(wěn)定(套餐都得是一份主食,副食及飲料)。當遇到這種場景時,使用生成器模式比較合適。
定義一個產(chǎn)品類:
public class Entity1{...} public class Entity2{...} public class Entity3{...} public class Product{ Entity1 entity1; Entity2 entity2; Entity3 entity3; }
產(chǎn)品類中的各個小模塊是不一樣的,由他們建造組成產(chǎn)品。
根據(jù)具體場景要求,定義n個生成器類:
public interface IBuild{ public void createEntity1(); public void createEntity2(); public void createEntity3(); public Product composite(); public Product create(); } public class BuildProduct implements IBuild{ Product p = new Product(); public void createEntity1(){ //p.entity1 = ... } public Product create(){ return composite(); } ...... } public class BuildProduct1 implements IBuild{ Product p = new Product(); public void createEntity1(){ //p.entity1 = ... } ...... }
定義一個指揮者類,統(tǒng)一調(diào)度project:
public class Director{ private IBuild build; public Director(IBuild build){ this.build = buid; } public Product build(){ build.create(); } public static void main(){ IBuild build = new BuildProduct(); Director direcotr = new Director(build); Prodcut p = director.build(); } }
優(yōu)點:
1、使用生成器模式可以使客戶端不必知道產(chǎn)品內(nèi)部組成的細節(jié)。
2、具體的建造者類之間是相互獨立的,對系統(tǒng)的擴展非常有利。
3、由于具體的建造者是獨立的,因此可以對建造過程逐步細化,而不對其他的模塊產(chǎn)生任何影響。
缺點:
建造者模式的“加工工藝”是暴露的,這樣使得建造者模式更加靈活,也使得工藝變得對客戶不透明。(待考證,筆者這里不是很理解,歡迎說自己的見解)
應用場景:
1、需要生成一個產(chǎn)品對象有復雜的內(nèi)部結(jié)構(gòu)。每一個內(nèi)部成分本身可以是對象,也可以使一個對象的一個組成部分。
2、需要生成的產(chǎn)品對象的屬性相互依賴。建造模式可以強制實行一種分步驟進行的建造過程。
3、在對象創(chuàng)建過程中會使用到系統(tǒng)中的其他一些對象,這些對象在產(chǎn)品對象的創(chuàng)建過程中不易得到
以上是“java如何實現(xiàn)生成器模式”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。