版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
創(chuàng)建型設計模式-建造者模式本章教學內容建造者模式模式動機與定義模式結構與分析模式實例與解析模式效果與應用模式擴展建造者模式模式動機無論是在現實世界中還是在軟件系統(tǒng)中,都存在一些復雜的對象,它們擁有多個組成部分,如汽車,它包括車輪、方向盤、發(fā)送機等各種部件。而對于大多數用戶而言,無須知道這些部件的裝配細節(jié),也幾乎不會使用單獨某個部件,而是使用一輛完整的汽車,可以通過建造者模式對其進行設計與描述,建造者模式可以將部件和其組裝過程分開,一步一步創(chuàng)建一個復雜的對象。用戶只需要指定復雜對象的類型就可以得到該對象,而無須知道其內部的具體構造細節(jié)。建造者模式模式動機建造者模式模式動機在軟件開發(fā)中,也存在大量類似汽車一樣的復雜對象,它們擁有一系列成員屬性,這些成員屬性中有些是引用類型的成員對象。而且在這些復雜對象中,還可能存在一些限制條件,如某些屬性沒有賦值則復雜對象不能作為一個完整的產品使用;有些屬性的賦值必須按照某個順序,一個屬性沒有賦值之前,另一個屬性可能無法賦值等。復雜對象相當于一輛有待建造的汽車,而對象的屬性相當于汽車的部件,建造產品的過程就相當于組合部件的過程。由于組合部件的過程很復雜,因此,這些部件的組合過程往往被“外部化”到一個稱作建造者的對象里,建造者返還給客戶端的是一個已經建造完畢的完整產品對象,而用戶無須關心該對象所包含的屬性以及它們的組裝方式,這就是建造者模式的模式動機。建造者模式模式定義建造者模式(BuilderPattern):將一個復雜對象的構建與它的表示分離,使得同樣的構建過程可以創(chuàng)建不同的表示。建造者模式是一步一步創(chuàng)建一個復雜的對象,它允許用戶只通過指定復雜對象的類型和內容就可以構建它們,用戶不需要知道內部的具體構建細節(jié)。建造者模式屬于對象創(chuàng)建型模式。根據中文翻譯的不同,建造者模式又可以稱為生成器模式。建造者模式模式定義BuilderPattern:Separatetheconstructionofacomplexobjectfromitsrepresentationsothatthesameconstructionprocesscancreatedifferentrepresentations.Frequencyofuse:mediumlow建造者模式模式結構建造者模式模式結構建造者模式包含如下角色:Builder:抽象建造者ConcreteBuilder:具體建造者Director:指揮者Product:產品角色建造者模式模式分析一個典型的復雜對象其類代碼示例如下:publicclassProduct{ privateStringpartA;//可以是任意類型
privateStringpartB; privateStringpartC; //partA的Getter方法和Setter方法省略
//partB的Getter方法和Setter方法省略
//partC的Getter方法和Setter方法省略}建造者模式模式分析抽象建造者類中定義了產品的創(chuàng)建方法和返回方法,其典型代碼如下:publicabstractclassBuilder{ protectedProductproduct=newProduct();
publicabstractvoidbuildPartA(); publicabstractvoidbuildPartB(); publicabstractvoidbuildPartC();
publicProductgetResult() { returnproduct; }}建造者模式模式分析建造者模式的結構中還引入了一個指揮者類Director,該類的作用主要有兩個:一方面它隔離了客戶與生產過程;另一方面它負責控制產品的生成過程。指揮者針對抽象建造者編程,客戶端只需要知道具體建造者的類型,即可通過指揮者類調用建造者的相關方法,返回一個完整的產品對象。
建造者模式模式分析指揮者類的代碼示例如下:publicclassDirector{ privateBuilderbuilder;
publicDirector(Builderbuilder) {
this.builder=builder; }
publicvoidsetBuilder(Builderbuilder) {
this.builder=builer; }
publicProductconstruct() {
builder.buildPartA();
builder.buildPartB();
builder.buildPartC(); returnbuilder.getResult(); }}建造者模式模式分析客戶端類代碼片段:在客戶端代碼中,無須關心產品對象的具體組裝過程,只需確定具體建造者的類型即可,建造者模式將復雜對象的構建與對象的表現分離開來,這樣使得同樣的構建過程可以創(chuàng)建出不同的表現。……Builderbuilder=newConcreteBuilder();Directordirector=newDirector(builder);Productproduct=director.construct();……建造者模式建造者模式實例與解析實例:KFC套餐建造者模式可以用于描述KFC如何創(chuàng)建套餐:套餐是一個復雜對象,它一般包含主食(如漢堡、雞肉卷等)和飲料(如果汁、可樂等)等組成部分,不同的套餐有不同的組成部分,而KFC的服務員可以根據顧客的要求,一步一步裝配這些組成部分,構造一份完整的套餐,然后返回給顧客。建造者模式建造者模式實例與解析KFC使用了建造者模式建造者模式建造者模式實例與解析實例:KFC套餐建造者模式模式優(yōu)缺點建造者模式的優(yōu)點在建造者模式中,客戶端不必知道產品內部組成的細節(jié),將產品本身與產品的創(chuàng)建過程解耦,使得相同的創(chuàng)建過程可以創(chuàng)建不同的產品對象。每一個具體建造者都相對獨立,而與其他的具體建造者無關,因此可以很方便地替換具體建造者或增加新的具體建造者,用戶使用不同的具體建造者即可得到不同的產品對象??梢愿泳毜乜刂飘a品的創(chuàng)建過程。將復雜產品的創(chuàng)建步驟分解在不同的方法中,使得創(chuàng)建過程更加清晰,也更方便使用程序來控制創(chuàng)建過程。增加新的具體建造者無須修改原有類庫的代碼,指揮者類針對抽象建造者類編程,系統(tǒng)擴展方便,符合“開閉原則”。建造者模式模式優(yōu)缺點建造者模式的缺點如下:建造者模式所創(chuàng)建的產品一般具有較多的共同點,其組成部分相似,如果產品之間的差異性很大,則不適合使用建造者模式,因此其使用范圍受到一定的限制。如果產品的內部變化復雜,可能會導致需要定義很多具體建造者類來實現這種變化,導致系統(tǒng)變得很龐大。建造者模式模式適用環(huán)境在以下情況下可以使用建造者模式:需要生成的產品對象有復雜的內部結構,這些產品對象通常包含多個成員屬性。需要生成的產品對象的屬性相互依賴,需要指定其生成順序。對象的創(chuàng)建過程獨立于創(chuàng)建該對象的類。在建造者模式中引入了指揮者類,將創(chuàng)建過程封裝在指揮者類中,而不在建造者類中。隔離復雜對象的創(chuàng)建和使用,并使得相同的創(chuàng)建過程可以創(chuàng)建不同的產品。建造者模式模式應用(1)JavaMail(一步一步構造一個完整的郵件對象,然后發(fā)送)……//由郵件會話對象新建一個郵件消息對象MimeMessagemessage=newMimeMessage(session);//設置郵件地址InternetAddressfrom=newInternetAddress("sunny@");message.setFrom(from);//設置發(fā)件人InternetAddressto=newInternetAddress(to_mail);message.setRecipient(Message.RecipientType.TO,to);//設置收件人,并設置其接收類型為TOmessage.setSubject(to_title);//設置主題message.setText(to_content);//設置信件內容message.setSentDate(newDate());//設置發(fā)信時間message.saveChanges();//存儲郵件信息Transporttransport=session.getTransport("smtp");transport.connect("","test","test");transport.sendMessage(message,message.getAllRecipients());……建造者模式模式應用(2)在很多游戲軟件中,地圖包括天空、地面、背景等組成部分,人物角色包括人體、服裝、裝備等組成部分,可以使用建造者模式對其進行設計,通過不同的具體建造者創(chuàng)建不同類型的地圖或人物。建造者模式模式模式建造者模式的簡化省略抽象建造者角色:如果系統(tǒng)中只需要一個具體建造者的話,可以省略掉抽象建造者。省略指揮者角色:在具體建造者只有一個的情況下,如果抽象建造者角色已經被省略掉,那么還可以省略指揮者角色,讓Builder角色扮演指揮者與建造者雙重角色。建造者模式模式模式建造者模式與抽象工廠模式的比較與抽象工廠模式相比,建造者模式返回一個組裝好的完整產品,而抽象工廠模式返回一系列相關的產品,這些產品位于不同的產品等級結構,構成了一個產品族。在抽象工廠模式中,客戶端實例化工廠類,然后調用工廠方法獲取所需產品對象,而在建造者模式中,客戶端可以不直接調用建造者的相關方法,而是通過指揮者類來指導如何生成對象,包括對象的組裝過程和建造步驟,它側重于一步步構造一個復雜對象,返回一個完整的對象。如果將抽象工廠模式看成汽車配件生產工廠,生產一個產品族的產品,那么建造者模式就是一個汽車組裝工廠,通過對部件的組裝可以返回一輛完整的汽車。本章小結建造者模式將一個復雜對象的構建與它的表示分離,使得同樣的構建過程可以創(chuàng)建不同的表示。建造者模式是一步一步創(chuàng)建一個復雜的對象,它允許用戶只通過指定復雜對象的類型和內容就可以構建它們,用戶不需要知道內部的具體構建細節(jié)。建造者模式屬于對象創(chuàng)建型模式。建造者模式包含如下四個角色:抽象建造者為創(chuàng)建一個產品對象的各個部件指定抽象接口;具體建造者實現了抽象建造者接口,實現各個部件的構造和裝配方法,定義并明確它所創(chuàng)建的復雜對象,也可以提供一個方法返回創(chuàng)建好的復雜產品對象;產品角色是被構建的復雜對象,包含多個組成部件;指揮者負責安排復雜對象的建造次序,指揮者與抽象建造者之間存在關聯(lián)關系,可以在其construct()建造方法中調用建造者對象的部件構造與裝配方法,完成復雜對象的建造。本章小結在建造者模式的結構中引入了一個指揮者類,該類的作用主要有兩個:一方面它隔離了客戶與生產過程;另一方面它負責控制產品的生成過程。指揮者針對抽象建造者編程,客戶端只需要知道具體建造者的類型,即可通過指揮者類調用建造者的相關方法,返回一個完整的產品對象。建造者模式的主要優(yōu)點在于客戶端不必知道產品內部組成的細節(jié),將產品本身與產品的創(chuàng)建過程解耦,使得相同的創(chuàng)建過程可以創(chuàng)建不同的產品對象,每一個具體建造者都相對獨立,而與其他的具體建造者無關,因此可以很方便地替換具體建造者或增加新的具體建造者,符合
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- GB/Z 110-2025固定鉛酸蓄電池和蓄電池組用射頻識別(RFID)試驗要求
- 員工試用期轉正工作總結15篇
- 2025年昆明市官渡區(qū)云南大學附屬中學星耀學校招聘備考題庫附答案詳解
- 人民警察基本級執(zhí)法資格考試題型及答案
- 2025國考國家稅務總局滁州市南譙區(qū)稅務局面試試題及答案解析
- 2025年廣州市民政局直屬事業(yè)單位第一次公開招聘工作人員25人備考題庫及一套答案詳解
- 三亞市公安局招聘下屬事業(yè)單位工作人員考試真題2024
- 2024年鞍山海城市教育局畢業(yè)生招聘考試真題
- 《CB 1153-1993金屬波形膨脹節(jié)》專題研究報告
- 2025廣西北海銀灘開發(fā)投資股份有限公司招聘2人考試核心題庫及答案解析
- 三防漆涂覆流程及質量控制標準
- 新生兒敗血癥診斷及治療專家共識(2024)解讀
- 知道智慧樹網課《統(tǒng)計學(中南財經政法大學)》課后章節(jié)測試答案
- 山東省齊魯名校大聯(lián)考2025-2026學年高三上學期10月月考英語試題
- 2025年貴州錦麟化工有限責任公司公開招聘13人筆試題庫歷年考點版附帶答案詳解
- 中山大學考試試題及答案
- 八年級英語上冊 Unit 7 單元綜合檢測(解析版)
- 《告訴你一個好消息》(2024年吉林長春中考滿分作文9篇附審題指導)
- 山西省煤礦安全b類題庫及答案解析
- 信息學考試題及答案
- 輸液泵和靜推泵課件
評論
0/150
提交評論