出版時(shí)間:2012-9 出版社:電子工業(yè)出版社 作者:[美]梅特斯克(Metsker,S.J.),[美]維克(Wake,W.J.) 譯者:張逸,史磊
Tag標(biāo)簽:無
內(nèi)容概要
本書通過一個(gè)完整的Java項(xiàng)目對(duì)經(jīng)典著作Design
Patterns一書介紹的23種設(shè)計(jì)模式進(jìn)行了深入分析與講解,實(shí)踐性強(qiáng),卻又不失對(duì)模式本質(zhì)的探討。本書創(chuàng)造性地將這些模式分為5大類別,以充分展現(xiàn)各個(gè)模式的重要特征,并結(jié)合UML類圖與對(duì)應(yīng)的Java程序,便于讀者更好地理解。全書給出了大量的練習(xí),作為對(duì)讀者的挑戰(zhàn),以啟發(fā)思考,督促讀者通過實(shí)踐練習(xí)的方式來掌握設(shè)計(jì)模式。同時(shí),作者又給出了這些練習(xí)的參考答案,使讀者可以印證比較,找出自己的不足,提高設(shè)計(jì)技能。
作者簡(jiǎn)介
作者:(美國(guó))史蒂芬?約翰?梅特斯克(Steven John Metsker) (美國(guó))威廉?維克(William C.Wake) 譯者:張逸 史磊 梅特斯克(Steven John Metsker)是Dominion Digital公司的管理顧問,該公司負(fù)責(zé)信息技術(shù)與商業(yè)過程的重新設(shè)計(jì)。Steven擅長(zhǎng)運(yùn)用面向?qū)ο蠹夹g(shù)構(gòu)建結(jié)構(gòu)清晰、功能強(qiáng)大的軟件系統(tǒng)。他還是Building Parsers with JavaTM、Design Pattern JavaTM Workbook與Design Patterns in C#(皆由Addison—Wesley出版)等著作的作者。 維克(William C.Wake)是一名獨(dú)立軟件咨詢師、教練和培訓(xùn)講師,他擁有超過二十年的軟件開發(fā)經(jīng)驗(yàn)。William C.Wake先后任職于Capital One Financial、DMR Trecom與VTLS。他Refactoring Workbook與ExtremeProgramming Explored(皆由Addison—Wesley出版)等著作的作者。
書籍目錄
序xv
第1章 緒論1
為何需要模式1
為何需要設(shè)計(jì)模式2
為何選擇Java3
UML3
挑戰(zhàn)4
本書的組織4
歡迎來到Oozinoz公司6
小結(jié)6
第1部分 接口型模式
第2章 接口型模式介紹8
接口與抽象類8
接口與職責(zé)10
小結(jié)11
超越普通接口12
第3章 適配器(Adapter)模式13
接口適配13
類與對(duì)象適配器17
JTable對(duì)數(shù)據(jù)的適配20
識(shí)別適配器24
小結(jié)25
第4章 外觀(Facade)模式27
外觀類、工具類和示例類27
重構(gòu)到外觀模式29
小結(jié)38
第5章 合成(Composite)模式39
常規(guī)組合39
合成模式中的遞歸行為40
組合、樹與環(huán)42
含有環(huán)的合成模式47
環(huán)的影響50
小結(jié)51
第6章 橋接(Bridge)模式52
常規(guī)抽象:橋接模式的一種方法52
從抽象到橋接模式54
使用橋接模式的驅(qū)動(dòng)器57
數(shù)據(jù)庫(kù)驅(qū)動(dòng)57
小結(jié)59
第2部分 職責(zé)型模式
第7章 職責(zé)型模式介紹62
常規(guī)的職責(zé)型模式62
根據(jù)可見性控制職責(zé)64
小結(jié)65
超越普通職責(zé)65
第8章 單例(Singleton)模式67
單例模式機(jī)制67
單例和線程68
識(shí)別單例70
小結(jié)71
第9章 觀察者(Observer)模式72
經(jīng)典范例:GUI中的觀察者模式72
模型/視圖/控制器76
維護(hù)Observable對(duì)象82
小結(jié)84
第10章 調(diào)停者(Mediator)模式85
經(jīng)典范例:GUI調(diào)停者(Mediator)85
關(guān)系一致性中的調(diào)停者模式89
小結(jié)96
第11章 代理(Proxy)模式97
經(jīng)典范例:圖像代理97
重新思考圖片代理102
遠(yuǎn)程代理104
動(dòng)態(tài)代理109
小結(jié)114
第12章 職責(zé)鏈(Chain of Responsibility)模式115
現(xiàn)實(shí)中的職責(zé)鏈模式115
重構(gòu)為職責(zé)鏈模式117
固定職責(zé)鏈119
沒有組合結(jié)構(gòu)的職責(zé)鏈模式121
小結(jié)121
第13章 享元(Flyweight)模式122
不變性122
抽取享元中不可變的部分123
共享享元125
小結(jié)128
第3部分 構(gòu)造型模式
第14章 構(gòu)造型模式介紹130
構(gòu)造函數(shù)的挑戰(zhàn)130
小結(jié)132
超出常規(guī)的構(gòu)造函數(shù)132
第15章 構(gòu)建者(Builder)模式134
常規(guī)的構(gòu)建者134
在約束條件下構(gòu)建對(duì)象137
可容錯(cuò)的構(gòu)建者139
小結(jié)140
第16章 工廠方法(Factory Method)模式141
經(jīng)典范例:迭代器141
識(shí)別工廠方法142
控制要實(shí)例化的類143
并行層次結(jié)構(gòu)中的工廠方法模式145
小結(jié)147
第17章 抽象工廠(Abstract Factory)模式148
經(jīng)典范例:圖形用戶界面工具箱148
抽象工廠和工廠方法153
包和抽象工廠157
小結(jié)157
第18章 原型(Prototype)模式158
作為工廠的原型158
利用克隆進(jìn)行原型化159
小結(jié)162
第19章 備忘錄(Memento)模式163
經(jīng)典范例:使用備忘錄模式執(zhí)行撤銷操作163
備忘錄的持久性170
跨會(huì)話的持久性備忘錄170
小結(jié)174
第4部分 操作型模式
第20章 操作型模式介紹176
操作和方法176
簽名177
異常178
算法和多態(tài)179
小結(jié)180
超越常規(guī)的操作181
第21章 模板方法(Template Method)模式182
經(jīng)典范例:排序182
完成一個(gè)算法186
模板方法鉤子188
重構(gòu)為模板方法模式189
小結(jié)191
第22章 狀態(tài)(State)模式193
對(duì)狀態(tài)進(jìn)行建模193
重構(gòu)為狀態(tài)模式197
使?fàn)顟B(tài)成為常量201
小結(jié)203
第23章 策略(Strategy)模式204
策略建模204
重構(gòu)到策略模式207
比較策略模式與狀態(tài)模式211
比較策略模式和模板方法模式211
小結(jié)212
第24章 命令(Command)模式213
經(jīng)典范例:菜單命令213
使用命令模式來提供服務(wù)216
命令鉤子217
命令模式與其他模式的關(guān)系219
小結(jié)220
第25章 解釋器(Interpreter)模式221
一個(gè)解釋器示例221
解釋器、語言和解析器233
小結(jié)234
第5部分 擴(kuò)展型模式
第26章 擴(kuò)展型模式介紹236
面向?qū)ο笤O(shè)計(jì)的原則236
Liskov替換原則237
迪米特法則238
消除代碼的壞味道239
超越常規(guī)的擴(kuò)展240
小結(jié)241
第27章 裝飾器(Decorator)模式242
經(jīng)典范例:流和輸出器242
函數(shù)包裝器250
裝飾器模式和其他設(shè)計(jì)模式的關(guān)系257
小結(jié)258
第28章 迭代器(Iterator)模式259
普通的迭代259
線程安全的迭代261
基于合成結(jié)構(gòu)的迭代267
小結(jié)277
第29章 訪問者(Visitor)模式278
訪問者模式機(jī)制278
常規(guī)的訪問者模式280
Visitor環(huán)286
訪問者模式的危機(jī)290
小結(jié)292
附錄A 指南293
附錄B 答案297
附錄C Oozinoz源代碼366
附錄D UML概覽369
參考文獻(xiàn)375
章節(jié)摘錄
版權(quán)頁: 插圖: 假設(shè)其他的開發(fā)者編寫了一個(gè)方法,用來查詢車間里所有機(jī)器擁有的原料桶的集合。一旦訪問到卸載緩沖池,如果unloadBuffer類的9etTubs0方法拋出異常,這段代碼就會(huì)出現(xiàn)問題。這嚴(yán)重違反了LSP:當(dāng)你將unloadBuffer對(duì)象當(dāng)做Machine對(duì)象來使用時(shí),程序可能會(huì)崩潰!假設(shè)不拋出異常,我們需要簡(jiǎn)單地忽略對(duì)unloadBuffer類中9etTubs0和addTubO的調(diào)用。這一做法依然違反了LSP,因?yàn)樵谀憬o機(jī)器添加一個(gè)原料桶時(shí),這個(gè)原料桶可能會(huì)消失! 違反LSP并不一定是設(shè)計(jì)缺陷。針對(duì)Oozinoz公司的這種情況,需要權(quán)衡一下,讓Machi ne類擁有大多數(shù)機(jī)器的行為和違反LSP原則,究竟哪個(gè)價(jià)值更大。重要的一點(diǎn)是意識(shí)到LSP,并且清楚為什么其他設(shè)計(jì)可能違反了LSP。 迪米特法則 在20世紀(jì)80年代后期,美國(guó)東北大學(xué)Demeter Project的成員嘗試編輯了一些規(guī)則,用于確保健康的面向?qū)ο缶幊?。?xiàng)目團(tuán)隊(duì)將這些規(guī)則稱為迪米特法則(Law ofDemeter,LoD)。KarlLieberherr和Ian Holland在Assuring Good Style for Object—Oriented Programs一文中全面地總結(jié)了這一規(guī)則。聲明認(rèn)為:非正式地說,迪米特法則要求每個(gè)方法只能給有限的對(duì)象發(fā)送消息,包括參數(shù)對(duì)象、[this]偽變量,以及[this]的直接子部分。文章隨后給出了該法則的正式定義。相對(duì)于完全理解迪米特法則的意圖,識(shí)別設(shè)計(jì)是否違反該法則更加容易。 假設(shè)你有一個(gè)Material Manager對(duì)象,該對(duì)象有一個(gè)方法接收一個(gè)Tub對(duì)象作為參數(shù)。Tub對(duì)象有一個(gè)Location屬性,該屬性返回一個(gè)Machi ne對(duì)象,用以表示桶被放在哪個(gè)位置。假設(shè)在Material Manager的方法中,想要知道機(jī)器是否可用,你可能會(huì)寫如下代碼: 如果這個(gè)挑戰(zhàn)僅僅讓你覺得形如a.b.c的表達(dá)式是錯(cuò)誤的,那就降低了迪米特法則的價(jià)值。事實(shí)上,Lieberherr和Holland希望迪米特法則能夠進(jìn)一步確定無誤地回答這樣的問題:是否可以遵循某種公式或法則來寫出更好的面向?qū)ο蟪绦??這篇闡釋迪米特法則的早期論文非常值得我們拜讀。就像Liskov替換原則一樣,如果知道并遵循這些規(guī)則,它就會(huì)幫助你寫出更好的代碼,一旦你的設(shè)計(jì)違背了這些原則,就能夠及時(shí)獲知。 你會(huì)發(fā)現(xiàn),遵循這些指導(dǎo)原則,擴(kuò)展性就能夠自然而然產(chǎn)生好的代碼。但是,對(duì)于很多開發(fā)者而言,面向?qū)ο蟮拈_發(fā)依然是一門藝術(shù)。對(duì)代碼庫(kù)的藝術(shù)擴(kuò)展源于藝術(shù)家們的實(shí)踐,而這些大師們依然在不斷地改進(jìn)他們的藝術(shù)。重構(gòu)就是諸多技藝中的一種工具,它可以在不改變既有功能的前提下,改善代碼的質(zhì)量。 消除代碼的壞味道 你可能寄希望于Liskov替換原則與迪米特法則,能夠永遠(yuǎn)地防止你寫出拙劣的代碼。不過,更實(shí)際的做法是運(yùn)用這些準(zhǔn)則來幫助發(fā)現(xiàn)代碼的壞味道,然后修復(fù)它。這是一種通用的實(shí)踐:先寫出可工作的代碼,然后找出代碼的問題,并且修復(fù)它,以提升代碼質(zhì)量。但是該如何準(zhǔn)確地識(shí)別問題呢?答案就是找到代碼的壞味道。在Refactoring:Improving the Design of ExitingCode(由Fowler等人在1999年編寫)一書中描述了22種壞味道,并給出了相應(yīng)的重構(gòu)手法。
編輯推薦
《Java設(shè)計(jì)模式(第2版)》適合各個(gè)層次的Java開發(fā)人員與設(shè)計(jì)人員閱讀,也可以作為學(xué)習(xí)Java與設(shè)計(jì)模式的參考讀物或教材。
圖書封面
圖書標(biāo)簽Tags
無
評(píng)論、評(píng)分、閱讀與下載