面向?qū)ο笙到y(tǒng)設(shè)計(jì)_第1頁(yè)
面向?qū)ο笙到y(tǒng)設(shè)計(jì)_第2頁(yè)
面向?qū)ο笙到y(tǒng)設(shè)計(jì)_第3頁(yè)
面向?qū)ο笙到y(tǒng)設(shè)計(jì)_第4頁(yè)
面向?qū)ο笙到y(tǒng)設(shè)計(jì)_第5頁(yè)
已閱讀5頁(yè),還剩146頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

面向?qū)ο笙到y(tǒng)設(shè)計(jì)第一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二本章主要內(nèi)容11.1軟件架構(gòu)的設(shè)計(jì)11.2高層結(jié)構(gòu)設(shè)計(jì)11.3面向?qū)ο笤O(shè)計(jì)方法11.4對(duì)象持久化與數(shù)據(jù)庫(kù)11.5設(shè)計(jì)原則11.6設(shè)計(jì)模式第二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.1軟件架構(gòu)的設(shè)計(jì)11.1.1什么是軟件架構(gòu)11.1.2多層應(yīng)用架構(gòu)設(shè)計(jì)11.1.3軟件框架第三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二1.架構(gòu)的概念建筑、文學(xué)、音樂(lè)、機(jī)械、電子、計(jì)算機(jī)軟硬件等領(lǐng)域都會(huì)使用“架構(gòu)(architecture)”這一概念。架構(gòu)都提供了系統(tǒng)最高層的設(shè)計(jì)方案,以確保建筑、小說(shuō)、樂(lè)曲、設(shè)備、計(jì)算機(jī)等系統(tǒng)滿足期望的特性。好的建筑應(yīng)該美觀、堅(jiān)固、實(shí)用好的計(jì)算機(jī)應(yīng)用系統(tǒng)應(yīng)該實(shí)用、好維護(hù)、可靠、性價(jià)比高架構(gòu)師(architect)需要發(fā)現(xiàn)特定系統(tǒng)的最重要的關(guān)注點(diǎn),設(shè)計(jì)某種折衷的總體方案以滿足關(guān)注點(diǎn)。架構(gòu)包含系統(tǒng)的一組基本結(jié)構(gòu)(structure),每種結(jié)構(gòu)都有各種類型的部件(component)及其關(guān)系構(gòu)成,架構(gòu)描述了這些部件的組合、相互調(diào)用參照、通信以及其他動(dòng)態(tài)交互。第四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二架構(gòu)和結(jié)構(gòu)的關(guān)系架構(gòu)是抽象無(wú)形的,體現(xiàn)高層全局的決策,就像文章的中心思想和提綱。結(jié)構(gòu)是具體有形的,體現(xiàn)決策的貫徹,如同文章的每個(gè)段落及細(xì)節(jié)描述。架構(gòu)包含了結(jié)構(gòu)的初步描述和決策。相同架構(gòu)的系統(tǒng),具體結(jié)構(gòu)允許有差異。第五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二使用橋梁來(lái)比喻橋梁的架構(gòu)設(shè)計(jì)可以使用草圖描述,架構(gòu)決定了橋梁的基本結(jié)構(gòu)部件。橋梁有梁式橋、拱橋、斜拉橋、懸索橋等架構(gòu)斜拉橋的基本結(jié)構(gòu):索塔主梁斜拉索第六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二使用橋梁來(lái)比喻橋梁的結(jié)構(gòu)設(shè)計(jì)則需要考慮各種部件的數(shù)量、材料、重量、形態(tài)等方面,是可以施工的嚴(yán)謹(jǐn)?shù)慕Y(jié)構(gòu)圖。架構(gòu)是抽象的,對(duì)結(jié)構(gòu)進(jìn)行了設(shè)計(jì)和限定,每座橋的結(jié)構(gòu)是具體有形的、元素組合千變?nèi)f化第七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二2.軟件架構(gòu)軟件架構(gòu)(softwarearchitecture)的定義沒(méi)有統(tǒng)一的版本,一般認(rèn)為:一個(gè)應(yīng)用程序或計(jì)算系統(tǒng)的軟件架構(gòu)是一個(gè)或一組結(jié)構(gòu),它包含組成系統(tǒng)的軟件元素、這些元素對(duì)外可見(jiàn)的性質(zhì)以及它們之間的關(guān)系。對(duì)外可見(jiàn)的性質(zhì)指軟件元素能夠提供的服務(wù)、性能特征、錯(cuò)誤處理、共享資源的用法等。軟件的一個(gè)結(jié)構(gòu)元素可能是一個(gè)子系統(tǒng)、構(gòu)件、進(jìn)程、庫(kù)、數(shù)據(jù)庫(kù)、計(jì)算結(jié)點(diǎn)、遺留系統(tǒng)等等。軟件架構(gòu)是最高層次的系統(tǒng)分解,它不會(huì)囊括所有的結(jié)構(gòu)和行為的定義,它只關(guān)注那些被認(rèn)為是重要的元素。架構(gòu)難以更改,一旦修改,意味著整個(gè)系統(tǒng)重建,而結(jié)構(gòu)修改只影響局部。第八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二3.軟件架構(gòu)模式大部分的架構(gòu)來(lái)源于有相似關(guān)注點(diǎn)的系統(tǒng)的總結(jié)和抽象,這些相似性被描述成某種特殊模式的架構(gòu)風(fēng)格,也就是架構(gòu)模式(architecturalpattern)。一種架構(gòu)模式就是一個(gè)經(jīng)驗(yàn)秘籍,架構(gòu)師在設(shè)計(jì)不同系統(tǒng)時(shí)可以重復(fù)使用這些先進(jìn)經(jīng)驗(yàn)。圖10.1就是橋梁的四種常用架構(gòu)模式。中國(guó)建筑有一種攢尖模式,被廣泛應(yīng)用在古典園林中,如三角、四角、五角、八角等亭子,宮殿、壇廟大量應(yīng)用。第九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二軟件架構(gòu)模式軟件架構(gòu)模式就是可重復(fù)使用的軟件結(jié)構(gòu)風(fēng)格。第十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二10.1.2多層應(yīng)用架構(gòu)模式分層的含義三層多層MVC架構(gòu)模式多層的物理配置第十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二1.分層的含義基于組件的軟件開(kāi)發(fā),組件根據(jù)橫向位置劃分為多層(N-Layer):下層組件負(fù)責(zé)對(duì)上層組件提供服務(wù)上層組件可以使用下層組件定義的服務(wù),但下層組件對(duì)上層組件一無(wú)所知。層與層之間通常是不透明的,每一層都具有獨(dú)立的職責(zé)不同層的軟件構(gòu)件可以分布在多臺(tái)機(jī)器上,也可以部署在同一臺(tái)機(jī)器上,形成物理上的多層(N-Tier)第十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二理解分層概念層次模型的理念就是將整個(gè)任務(wù)橫向劃分為不同級(jí)別,而不是縱向比如學(xué)校管理縱向劃分有教學(xué)、人事、財(cái)務(wù)、后勤等任務(wù)橫向劃分有主管校長(zhǎng)(高層)、部門領(lǐng)導(dǎo)(中層)、普通員工(基層),或處、科、室計(jì)算機(jī)程序的組織結(jié)構(gòu)也可以有縱向劃分和橫向劃分縱向:教師管理功能、學(xué)生管理功能、課程管理功能……橫向:界面窗體、業(yè)務(wù)邏輯類、數(shù)據(jù)訪問(wèn)類……第十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二理解分層概念自從C/S出現(xiàn)之后,軟件就被分層了:Client端的軟件完成前臺(tái)任務(wù),Server端的軟件完成后臺(tái)任務(wù)(一般是DBServer);Client使用Server端的服務(wù),依賴于Server端。自從Internet出現(xiàn)之后,軟件進(jìn)一步分層:Client端的軟件(IE瀏覽器)完成輸入輸出任務(wù),WebServer上的程序提供業(yè)務(wù)邏輯處理,后臺(tái)DBServer完成數(shù)據(jù)的存取。C/S常被稱為傳統(tǒng)的兩層,B/S稱為三層。本書(shū)的分層將不包含有關(guān)系統(tǒng)軟件(屏蔽如IE、DBMS等內(nèi)容),僅討論應(yīng)用系統(tǒng)本身的設(shè)計(jì),即應(yīng)用架構(gòu)設(shè)計(jì)。第十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二2.三個(gè)基本層次應(yīng)用軟件內(nèi)部也可以進(jìn)行多層的劃分。比如一個(gè)用戶注冊(cè)程序可以劃分為兩層:Register.aspx/Register.aspx.cs窗體:負(fù)責(zé)界面數(shù)據(jù)的輸入和格式檢驗(yàn),結(jié)果的輸出等。Person類:負(fù)責(zé)數(shù)據(jù)庫(kù)訪問(wèn)和注冊(cè)規(guī)則檢查等。從應(yīng)用層面上看,如果整個(gè)應(yīng)用軟件都是采用這種方式編程(如訂單處理由PlaceOrder.aspx窗體負(fù)責(zé)界面交互,由Order、Product等類負(fù)責(zé)數(shù)據(jù)庫(kù)訪問(wèn)和訂單金額計(jì)算等業(yè)務(wù)邏輯處理),那么稱之為兩層的應(yīng)用架構(gòu)??梢杂袃蓪?、三層、四層等不同分層模式。Register.aspx/Register.aspx.cs窗體PersonBll類:負(fù)責(zé)注冊(cè)規(guī)則檢查等業(yè)務(wù)邏輯。PersonDal類:負(fù)責(zé)數(shù)據(jù)庫(kù)訪問(wèn)。第十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二傳統(tǒng)的C/S應(yīng)用程序界面窗口程序中包含所有的內(nèi)容,如輸入輸出、界面邏輯控制、業(yè)務(wù)邏輯運(yùn)算等。系統(tǒng)架構(gòu)是兩層,應(yīng)用架構(gòu)沒(méi)有分層。數(shù)據(jù)庫(kù)第十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二經(jīng)典的三層架構(gòu)數(shù)據(jù)庫(kù)借還書(shū)組件讀者管理組件表示層(UI)業(yè)務(wù)邏輯層(BLL)數(shù)據(jù)訪問(wèn)層(DAL)數(shù)據(jù)庫(kù)訪問(wèn)組件第十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二經(jīng)典的三層架構(gòu)表現(xiàn)層:處理用戶和信息系統(tǒng)之間的交互。可以是簡(jiǎn)單的命令行窗口,也可以功能完善的圖形用戶界面(胖客戶端程序),如基于HTML的瀏覽器界面(瘦客戶端程序),也可以是手機(jī)界面。業(yè)務(wù)邏輯層:也稱為領(lǐng)域?qū)踊驊?yīng)用層,是信息系統(tǒng)所有和領(lǐng)域相關(guān)的工作。如根據(jù)輸入數(shù)據(jù)或已有數(shù)據(jù)進(jìn)行計(jì)算,可以是類庫(kù)或Web服務(wù)。依賴于數(shù)據(jù)訪問(wèn)層獲取數(shù)據(jù)或保存數(shù)據(jù)。數(shù)據(jù)訪問(wèn)層:一般指與數(shù)據(jù)庫(kù)的交互,主要責(zé)任是數(shù)據(jù)庫(kù)記錄的存取。如組件中包含專門的數(shù)據(jù)訪問(wèn)類,或每個(gè)表對(duì)應(yīng)一個(gè)數(shù)據(jù)訪問(wèn)類第十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二3.擴(kuò)展的五層架構(gòu)表現(xiàn)層:等同于三層中的表現(xiàn)層。控制層/中介層:是表現(xiàn)層和領(lǐng)域?qū)拥闹薪閷?,也稱應(yīng)用控制器。主要表示業(yè)務(wù)邏輯中的工作流,一般針對(duì)于用例的事件流控制。此外還負(fù)責(zé)會(huì)話狀態(tài)、數(shù)據(jù)的合成或分解等事務(wù)。領(lǐng)域?qū)樱簶I(yè)務(wù)邏輯中的領(lǐng)域類的集合,不包含復(fù)雜工作流。數(shù)據(jù)映射層:負(fù)責(zé)將基于對(duì)象的領(lǐng)域?qū)訑?shù)據(jù)映射到數(shù)據(jù)庫(kù)關(guān)系表中的記錄。也稱為數(shù)據(jù)持久層,可自行開(kāi)發(fā)或采用持久化框架。數(shù)據(jù)訪問(wèn)層:負(fù)責(zé)數(shù)據(jù)庫(kù)表的增刪改查等操作。持久化框架中包含該層組件。第十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二4.MVC架構(gòu)模式模型(Model)代表數(shù)據(jù),使用對(duì)象及其屬性實(shí)現(xiàn)??刂破鳎–ontroller)是模型與視圖的聯(lián)系紐帶,客戶的請(qǐng)求由控制器處理,它根據(jù)客戶的請(qǐng)求調(diào)用模型的方法,完成數(shù)據(jù)更新,然后調(diào)用視圖的方法將響應(yīng)結(jié)果展示給客戶。相應(yīng)的,模型的更新與修改將通過(guò)控制器通知視圖,保持視圖與模型的一致性視圖(View)是模型的外在表現(xiàn)形式,視圖可以直接訪問(wèn)模型;查詢數(shù)據(jù)信息,當(dāng)模型中數(shù)據(jù)發(fā)生變化時(shí),它會(huì)通知視圖刷新界面,顯示更新后的數(shù)據(jù)。第二十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二MVC架構(gòu)示意圖MVC模式和三層模式有共同特點(diǎn)(業(yè)務(wù)邏輯、數(shù)據(jù)和表示的分離),但不完全遵守分層約定。第二十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二MVC架構(gòu)模式工作流程控制器對(duì)象負(fù)責(zé)頁(yè)面轉(zhuǎn)向,并傳遞頁(yè)面數(shù)據(jù)第二十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二5.多層的物理配置由于應(yīng)用軟件封裝成不同層次的獨(dú)立組件,這給軟件部署帶來(lái)了靈活性:物理一層:所有應(yīng)用軟件的組件都安裝配置在一臺(tái)機(jī)器上。比如全部Web程序、DBMS都在Web服務(wù)器上。物理兩層:應(yīng)用軟件的組件配置在兩臺(tái)機(jī)器上,比如一部分安裝在客戶端,另一部分配置在應(yīng)用服務(wù)器上。物理多層:客戶端、一臺(tái)或多臺(tái)應(yīng)用服務(wù)器、數(shù)據(jù)庫(kù)服務(wù)器,即多臺(tái)服務(wù)器的方式,這是分布式結(jié)構(gòu)的一種形式。第二十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二多層體系結(jié)構(gòu)的優(yōu)勢(shì)客戶對(duì)數(shù)據(jù)的訪問(wèn)通過(guò)中間層進(jìn)行了隔離,數(shù)據(jù)庫(kù)的安全性提高了。應(yīng)用程序分布部署在多個(gè)物理節(jié)點(diǎn)上成為可能,從而增強(qiáng)了處理大量的用戶負(fù)載或計(jì)算任務(wù)的能力,系統(tǒng)可靠性和響應(yīng)速度得到了提高。業(yè)務(wù)邏輯處于不同的中間服務(wù)器,當(dāng)業(yè)務(wù)規(guī)則變化后,客戶端程序基本不做改動(dòng),當(dāng)組件接口不變時(shí),某一層的改動(dòng)不會(huì)影響其它層,這也意味著更好的重用和可維護(hù)性(如從窗口界面變更到Web界面)。將不同層的開(kāi)發(fā)任務(wù)在開(kāi)發(fā)者之間適當(dāng)?shù)胤峙洌ㄈ缫恍┤藢W㈨?yè)面表現(xiàn),另一些人專注于業(yè)務(wù)邏輯),有效地利用開(kāi)發(fā)人員的專長(zhǎng)和開(kāi)發(fā)技巧,并且能夠提高并行開(kāi)發(fā)能力。第二十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.1.3軟件框架“不要重復(fù)發(fā)明輪子”軟件復(fù)用:從代碼角度(開(kāi)發(fā)態(tài))看有子過(guò)程、函數(shù)、類等從部署角度(運(yùn)行態(tài))看有類庫(kù)、Web服務(wù)等二進(jìn)制可執(zhí)行組件、中間件和平臺(tái)架構(gòu)模式同樣可以復(fù)用,當(dāng)架構(gòu)模式的復(fù)用形式不僅僅停留在邏輯層面,而以物理的二進(jìn)制組件的方式提供重用時(shí),就產(chǎn)生了框架。第二十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二1.軟件框架的概念軟件框架(softwareframework)是對(duì)整個(gè)或部分系統(tǒng)可重用的設(shè)計(jì)和實(shí)現(xiàn)??蚣芸梢赃x擇對(duì)某種架構(gòu)模式的基本結(jié)構(gòu)和接口機(jī)制進(jìn)行編程實(shí)現(xiàn),不僅封裝該架構(gòu)模式的基本元素對(duì)外提供類庫(kù),還封裝底層公用的流程控制邏輯,從而直接為應(yīng)用軟件提供了最初的骨架??蚣芫褪且粋€(gè)半成品軟件平臺(tái),軟件框架和應(yīng)用軟件:八股文/元芳體與具體文章汽車流水線與汽車第二十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二基于框架的軟件開(kāi)發(fā)引入軟件框架之后,整個(gè)開(kāi)發(fā)過(guò)程變成了“分三步走”:決定應(yīng)用架構(gòu)選擇實(shí)現(xiàn)應(yīng)用架構(gòu)的框架基于框架之下編寫(xiě)程序(簡(jiǎn)單、統(tǒng)一)優(yōu)點(diǎn):代碼具有相同規(guī)范和結(jié)構(gòu),易于理解和維護(hù);提高效率;更穩(wěn)定更可靠。局限:囿于框架所限定的“框框”之內(nèi)構(gòu)建應(yīng)用程序,比較死板,缺乏靈活性第二十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二典型框架產(chǎn)品支持MVC架構(gòu)模式的框架:Java開(kāi)源MVC框架Struts微軟平臺(tái)的MVC4框架PHP的Zend框架多種框架產(chǎn)品的組合使用:如SSH(Struts、Spring、Hibernate)第二十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二Struts2簡(jiǎn)介MVC:View:由JSP頁(yè)面實(shí)現(xiàn)Model:由自行編寫(xiě)的Action對(duì)象完成,Action類就是一個(gè)普通的Java類,里面封裝了領(lǐng)域?qū)ο蟮膶傩院头椒ǎ梢杂糜诖嫒?shù)據(jù)和執(zhí)行有關(guān)業(yè)務(wù)邏輯。屬性和方法也可以分開(kāi)到不同類中。Controller:由Struts2的內(nèi)置過(guò)濾器(dispatcherfilter)、攔截器(interceptor)或自行編寫(xiě)的攔截器來(lái)實(shí)現(xiàn),過(guò)濾器和攔截器可以截獲JSP頁(yè)面請(qǐng)求,解析http請(qǐng)求中的參數(shù),賦值給Action對(duì)象中對(duì)應(yīng)的屬性,還可以在調(diào)用Action之前或之后進(jìn)行預(yù)處理或后處理。第二十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.2高層結(jié)構(gòu)設(shè)計(jì)高層結(jié)構(gòu)討論系統(tǒng)比較大的組成部件(如包、構(gòu)件、子系統(tǒng)等)及其接口設(shè)計(jì)。11.2.1包11.2.2子系統(tǒng)及接口11.2.3構(gòu)件及接口第三十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.2.1包包(Package)是一種邏輯分組手段,可以取UML模型中的任何一種事物,將相關(guān)成分聚在一起,以構(gòu)成更高層的組織單元——包。最常用的方法是將類以包為單位進(jìn)行分組,比如上一節(jié)提到的層,每一層中的所有類組成一個(gè)包。一個(gè)包可以包含其它的包,高層包被分成若干子包,子包又可以在分成更小的包。但在Java中,包還指代了物理的組織手段第三十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二如何分包分包(軟件類的分組)有兩種原則:共同封閉原則(CommonClosurePrinciple)。一個(gè)包中的各個(gè)類應(yīng)該是由于相似的原則而改變,即將一組職責(zé)相似、但以不同方式實(shí)現(xiàn)的類歸為一個(gè)包中。比如按照層來(lái)進(jìn)行分包就是這種類型。共同復(fù)用原則(CommonReusePrinciple)。一個(gè)包中的各個(gè)類應(yīng)該一起被復(fù)用,復(fù)用其中一個(gè)可能需要同時(shí)考慮同一個(gè)包中的其它協(xié)作類。通常和業(yè)務(wù)功能相關(guān)。第三十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二包圖包圖用來(lái)描述包及其依賴關(guān)系。當(dāng)表現(xiàn)層包中的類要使用領(lǐng)域包中的領(lǐng)域類提供的服務(wù)時(shí),表示包就依賴于領(lǐng)域包。第三十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.2.2子系統(tǒng)及接口當(dāng)按照相對(duì)完整和獨(dú)立的業(yè)務(wù)功能或管理職能組織包,并對(duì)這樣的包進(jìn)行封裝后,一個(gè)高層的具有特定功能的可以運(yùn)行的獨(dú)立構(gòu)件就產(chǎn)生了,稱為子系統(tǒng)(Subsystem)。子系統(tǒng)對(duì)外可以提供有限的接口,只要接口不改變,不管子系統(tǒng)內(nèi)部發(fā)生什么變化,也不會(huì)影響到依賴于該子系統(tǒng)接口的其它子系統(tǒng)。子系統(tǒng)及其關(guān)系使用UML構(gòu)件圖(componentdiagram)描述。第三十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二理解接口概念詞典釋義兩個(gè)不同系統(tǒng)(或子程序)交接并通過(guò)它彼此作用的部分。人類與計(jì)算機(jī)之間的接口稱為用戶接口。計(jì)算機(jī)硬件元件間的接口叫硬件接口。計(jì)算機(jī)軟件元件間的接口叫軟件接口。內(nèi)部接口:系統(tǒng)內(nèi)部各元件間的接口外部接口:系統(tǒng)對(duì)外提供給其他系統(tǒng)使用的接口API:應(yīng)用編程接口(ApplicationProgrammingInterface),一種應(yīng)用程序提供的外部接口的說(shuō)法第三十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二區(qū)分子系統(tǒng)和包子系統(tǒng)與包在語(yǔ)義上具有差異:子系統(tǒng)是一種通過(guò)一個(gè)或多個(gè)它所實(shí)現(xiàn)的接口來(lái)提供行為的軟件單位,可運(yùn)行,具有物理意義。包并不提供行為,包只不過(guò)是用來(lái)容納各種其他模型元素的容器,一般是邏輯意義上的。第三十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二子系統(tǒng)的關(guān)系財(cái)務(wù)子系統(tǒng)將內(nèi)部操作進(jìn)行了封裝,但對(duì)外提供必要的接口(比如一組函數(shù))銷售子系統(tǒng)在執(zhí)行銷售業(yè)務(wù)過(guò)程中可以使用該接口對(duì)銷售數(shù)據(jù)執(zhí)行某些財(cái)務(wù)操作。對(duì)于銷售子系統(tǒng)而言,依賴的是財(cái)務(wù)子系統(tǒng)的接口,并不需要關(guān)心財(cái)務(wù)子系統(tǒng)的具體實(shí)現(xiàn)。采用UML2.0的構(gòu)件圖表示如下:第三十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二子系統(tǒng)的關(guān)系子系統(tǒng)之間的關(guān)系:數(shù)據(jù)接口:定義相互可以理解的數(shù)據(jù)格式和數(shù)據(jù)文件,子系統(tǒng)之間采用數(shù)據(jù)文件進(jìn)行通信。服務(wù)接口:定義相互可以理解的軟件服務(wù)(操作、消息),子系統(tǒng)之間采用發(fā)送服務(wù)請(qǐng)求和響應(yīng)來(lái)進(jìn)行通信。思考:教務(wù)管理系統(tǒng)(基礎(chǔ)數(shù)據(jù)子系統(tǒng)、排課子系統(tǒng)、成績(jī)管理子系統(tǒng)、畢設(shè)管理子系統(tǒng)),各子系統(tǒng)是否有關(guān)系?第三十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二不同系統(tǒng)的關(guān)系子系統(tǒng)及接口關(guān)系也可以擴(kuò)展到不同系統(tǒng)及接口關(guān)系,如學(xué)籍管理系統(tǒng)與其他系統(tǒng)的關(guān)系需要服務(wù):高招系統(tǒng)(獲取學(xué)生信息)、教委學(xué)位系統(tǒng)(學(xué)位數(shù)據(jù)上報(bào))本系統(tǒng)需要提供的服務(wù):提供學(xué)生學(xué)籍信息同樣可采用UML構(gòu)件圖描述:學(xué)籍管理系統(tǒng)高招系統(tǒng)教委系統(tǒng)發(fā)布錄取學(xué)生學(xué)位授予上報(bào)檔案系統(tǒng)提供學(xué)籍信息第三十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.2.2構(gòu)件及接口構(gòu)件(component)是系統(tǒng)中實(shí)際存在的可更換部分,它實(shí)現(xiàn)特定的功能,符合一套接口標(biāo)準(zhǔn)并實(shí)現(xiàn)一組接口。構(gòu)件是可復(fù)用的軟件組成成份,可被用來(lái)構(gòu)造其他軟件。在系統(tǒng)中采用構(gòu)件軟件程序不需要重新編譯,也不需要構(gòu)件自身的源代碼并且不局限于某一種編程語(yǔ)言,所以構(gòu)件的復(fù)用也稱為二進(jìn)制復(fù)用(binaryreuse),因?yàn)樗墙⒃诮涌诙皇窃创a級(jí)別的復(fù)用。構(gòu)件及其關(guān)系使用UML構(gòu)件圖描述。第四十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二構(gòu)件圖1構(gòu)件之間存在依賴關(guān)系:DataAccess構(gòu)件用于實(shí)現(xiàn)數(shù)據(jù)存取訪問(wèn),對(duì)外提供接口名為SearchInDB(查詢數(shù)據(jù)庫(kù),接口參數(shù)等細(xì)節(jié)省略)。Book構(gòu)件實(shí)現(xiàn)圖書(shū)的管理,對(duì)外提供SearchBook(查詢圖書(shū))和ExportToXml(導(dǎo)出圖書(shū)為XML文件)兩個(gè)接口。Book構(gòu)件需要使用DataAccess構(gòu)件提供的接口,即構(gòu)件Book依賴于DataAccess構(gòu)件。

DataAccessBookSearchBookExportToXmlSearchInDB第四十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二區(qū)分子系統(tǒng)和構(gòu)件子系統(tǒng)和構(gòu)件在結(jié)構(gòu)上具有差異:子系統(tǒng)是一個(gè)系統(tǒng),是有特定功能的整體,可以直接使用,不會(huì)被復(fù)用。構(gòu)件只是構(gòu)成系統(tǒng)的元素,不具備單獨(dú)使用的能力,用于復(fù)用。第四十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.3面向?qū)ο笤O(shè)計(jì)方法10.4.1根據(jù)架構(gòu)設(shè)計(jì)軟件類10.4.2設(shè)計(jì)類的屬性10.4.3設(shè)計(jì)類的方法10.4.4設(shè)計(jì)類的關(guān)系第四十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.3.1根據(jù)架構(gòu)設(shè)計(jì)軟件類一種3層的分層模式:從分析模型的領(lǐng)域類導(dǎo)出設(shè)計(jì)階段中的實(shí)體類增加邊界類和控制類完成程序的交互和控制。為了分辨出類的這三種不同類型,可以采用UML提供的擴(kuò)展機(jī)制——構(gòu)造型(stetreotype)及其表達(dá)符號(hào)來(lái)定義模型元素構(gòu)造型第四十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二Rose中不同構(gòu)造型的圖符<<邊界類>><<實(shí)體類>><<控制類>>系統(tǒng)邊界對(duì)象行為的控制和協(xié)調(diào)系統(tǒng)服務(wù)和信息第四十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二分層的軟件類協(xié)作實(shí)現(xiàn)一個(gè)用例第四十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二1、邊界類邊界類的職責(zé)是完成系統(tǒng)與其參與者之間的交互。接收來(lái)自用戶和外部系統(tǒng)的信息與請(qǐng)求將信息與請(qǐng)求提交給用戶和外部系統(tǒng)通過(guò)用例圖可以得知每個(gè)邊界類至少應(yīng)該與一個(gè)參與者有關(guān),參與者類型不同,邊界類的設(shè)計(jì)也不同邊界類包括屏幕窗口、通信接口、打印機(jī)接口、傳感器、終端以及專用API(應(yīng)用程序編程接口)等軟件對(duì)象。對(duì)于圖書(shū)館系統(tǒng)來(lái)說(shuō),參與者都是系統(tǒng)用戶,因此邊界類只有窗口界面這一種形式。假如考慮提供館際互借業(yè)務(wù),那么系統(tǒng)就會(huì)產(chǎn)生與其它外部合作的圖書(shū)館系統(tǒng)的交互,這時(shí)與外部系統(tǒng)間的通信接口也是一種邊界類第四十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二識(shí)別邊界類:圖書(shū)管理員?boundary?:借書(shū)用戶界面圖書(shū)管理員借出圖書(shū)根據(jù)用例圖,每個(gè)參與者與一個(gè)用例交互,必定導(dǎo)出一個(gè)邊界類第四十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館系統(tǒng)的用例圖第四十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二2、實(shí)體類實(shí)體類來(lái)源于領(lǐng)域模型中的類。實(shí)體類是一個(gè)軟件對(duì)象,表示了領(lǐng)域?qū)ο蟮男畔ⅲ约熬哂信c它所表示的信息有關(guān)的操作。實(shí)體類反映的信息需要在系統(tǒng)中進(jìn)行處理,并需要進(jìn)行持久化存儲(chǔ)。持久化存儲(chǔ)可以由實(shí)體類來(lái)實(shí)現(xiàn),也可以設(shè)計(jì)專門的數(shù)據(jù)訪問(wèn)類來(lái)完成。第五十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二邊界類和實(shí)體類的交互邊界類僅負(fù)責(zé)數(shù)據(jù)的輸入和輸出,不應(yīng)承擔(dān)和數(shù)據(jù)處理有關(guān)的業(yè)務(wù)邏輯,可負(fù)責(zé)部分不太復(fù)雜的數(shù)據(jù)校驗(yàn)功能(如非空檢查、多個(gè)輸入域之間的約束和聯(lián)動(dòng))。邊界類通過(guò)與實(shí)體類的交互,獲得有關(guān)數(shù)據(jù)處理的結(jié)果:圖書(shū)管理員驗(yàn)證?boundary?:借書(shū)用戶界面?entity?:讀者第五十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二3、控制類控制類代表協(xié)調(diào)、排序、事務(wù)處理以及對(duì)其它對(duì)象的控制,經(jīng)常用于封裝與某個(gè)具體用例有關(guān)的控制流。控制類處理和協(xié)調(diào)用例事件流中的主要?jiǎng)幼骱涂刂屏?,并將部分任?wù)委派給其它對(duì)象。根據(jù)分層原則,控制類不封裝與參與者交互有關(guān)的內(nèi)容,也不封裝與系統(tǒng)處理的長(zhǎng)效持久的信息有關(guān)的問(wèn)題,這些問(wèn)題分別由邊界類和實(shí)體類進(jìn)行封裝。第五十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二識(shí)別控制類當(dāng)用例邏輯較為復(fù)雜,并涉及到多個(gè)實(shí)體類時(shí),可以考慮采用控制類簡(jiǎn)化方案:控制類的職責(zé)合并給邊界類獲取驗(yàn)證:圖書(shū)管理員創(chuàng)建?boundary?:借書(shū)用戶界面?control?:借書(shū)控制類?entity?:讀者?entity?:資源項(xiàng)目?entity?:借書(shū)記錄第五十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二不同類的職責(zé)分配向下依賴的關(guān)系:邊界類負(fù)責(zé)與參與者的交互(輸入數(shù)據(jù)、顯示數(shù)據(jù))為GUI的每個(gè)彈出式屏幕創(chuàng)建一個(gè)邊界對(duì)象。控制類(可選)負(fù)責(zé)一個(gè)用例的事件流,或部分復(fù)雜數(shù)據(jù)流實(shí)體類負(fù)責(zé)數(shù)據(jù)的封裝為每個(gè)領(lǐng)域類創(chuàng)建一個(gè)實(shí)體類第五十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館系統(tǒng)的界面類第五十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館系統(tǒng)的控制類第五十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館系統(tǒng)的實(shí)體類第五十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二其他架構(gòu)方案上述三層架構(gòu):表現(xiàn)層/控制層/實(shí)體層MVC框架:每個(gè)功能對(duì)應(yīng)一個(gè)頁(yè)面類,即View(邊界類)每個(gè)頁(yè)面的請(qǐng)求都由Control類負(fù)責(zé)處理(控制類)Control類使用Model類存取數(shù)據(jù)(實(shí)體類)架構(gòu)不同,要設(shè)計(jì)的軟件類也不同第五十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.3.2設(shè)計(jì)類的屬性屬性類型和初值屬性的類型和默認(rèn)的初始值應(yīng)該在設(shè)計(jì)模型中表示出來(lái)。類型和屬性名之間用冒號(hào)隔開(kāi),等號(hào)之后寫(xiě)初值。選擇的數(shù)據(jù)類型最好是目標(biāo)語(yǔ)言中可用的。關(guān)聯(lián)屬性屬性的可見(jiàn)性類中的每個(gè)屬性可以有可見(jiàn)性定義,指定該屬性可以被其它類利用的程度,UML定義了4種屬性可見(jiàn)性:公有(public)“+”受保護(hù)(protected)“#”私有(private)“-”包(package)“~”第五十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館類圖第六十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.3.3建立用戶界面原型用戶界面原型是一個(gè)草圖,包含用例提到的系統(tǒng)和用戶進(jìn)行交互的必要元素界面原型不描述太多細(xì)節(jié),通常包含以下內(nèi)容:需要由用戶輸入到系統(tǒng)中的數(shù)據(jù)窗口或表格;需要由系統(tǒng)執(zhí)行的操作按鈕;系統(tǒng)應(yīng)及時(shí)做出回應(yīng)的事件;需要由系統(tǒng)輸出給用戶的數(shù)據(jù)窗口或消息。第六十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二借書(shū)界面設(shè)計(jì)第六十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二借書(shū)界面設(shè)計(jì)界面數(shù)據(jù)說(shuō)明第六十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二借書(shū)界面設(shè)計(jì)界面事件及響應(yīng)說(shuō)明第六十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館系統(tǒng)的還書(shū)界面第六十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.3.4設(shè)計(jì)類的方法交互圖中的消息映射為接受消息的對(duì)象類的方法(操作)消息表達(dá)式中的參數(shù)和返回值等映射為類方法函數(shù)的參數(shù)和返回值同義詞釋疑:操作是關(guān)于行為的定義,方法是行為的實(shí)現(xiàn),服務(wù)是行為的對(duì)外表現(xiàn),消息是行為如何協(xié)作,它們用于不同的角度、場(chǎng)合、時(shí)機(jī)和模型中,但可以將它們認(rèn)為是同義詞第六十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二1.職責(zé)類的方法是對(duì)象應(yīng)該執(zhí)行的操作,也稱為對(duì)象的職責(zé)和義務(wù)。職責(zé)是在設(shè)計(jì)過(guò)程中分配給每個(gè)類的,可以采取的方法有:使用交互圖使用CRC技術(shù)第六十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二職責(zé)完成的兩種情況一項(xiàng)職責(zé)的完成有以下兩種情況:1.由某個(gè)對(duì)象獨(dú)立承擔(dān),比如“計(jì)算超期天數(shù)”由一個(gè)Loan對(duì)象負(fù)責(zé)。2.主要由一個(gè)對(duì)象負(fù)責(zé),但該對(duì)象將職責(zé)進(jìn)行了二次分配或分解。比如“負(fù)責(zé)計(jì)算訂單總額”應(yīng)該由一個(gè)Order對(duì)象負(fù)責(zé),Order類為了完成該職責(zé),需求OrderItem對(duì)象的協(xié)作,OrderItem對(duì)象負(fù)責(zé)提供每個(gè)訂單項(xiàng)的小計(jì)金額(數(shù)量*單價(jià))。軟件對(duì)象的職責(zé)分配可以映射到現(xiàn)實(shí)世界中的分工和協(xié)作,例如:部門經(jīng)理A布置業(yè)務(wù)人員B完成一項(xiàng)任務(wù)x,B可能一個(gè)人獨(dú)立承擔(dān)該任務(wù),B也可能將任務(wù)分解為x1、x2、x3,自己負(fù)責(zé)x1和x2,請(qǐng)C負(fù)責(zé)x3。第六十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二職責(zé)的兩種類型職責(zé)有兩種類型:1.行為型:即對(duì)象本身的方法。比如進(jìn)行一項(xiàng)計(jì)算、被創(chuàng)建時(shí)的初始化、執(zhí)行控制或協(xié)調(diào)的各項(xiàng)活動(dòng)。2.了解型:對(duì)象應(yīng)掌握的信息。比如對(duì)象自身的數(shù)據(jù)和屬性、相關(guān)聯(lián)的對(duì)象以及能夠派生或計(jì)算的對(duì)象(set/get方法),如Loan類需要了解借出和歸還日期(屬性),以及所借資源的有關(guān)情況,即ResourceItem或ResourceTitle對(duì)象(關(guān)聯(lián)對(duì)象)。第六十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二CRC卡片法CRC卡片法是一種職責(zé)分配技術(shù),CRC是類-職責(zé)-協(xié)作(Class-Responsibility-Collaboration)的簡(jiǎn)稱。具體實(shí)踐過(guò)程:首先為系統(tǒng)中每個(gè)軟件類制作一張卡片選取一個(gè)用例,確定該用例的參與類取出上述確定的類卡片通過(guò)移動(dòng)卡片來(lái)討論類如何協(xié)作完成用例功能最后將形成的職責(zé)概念記錄在類所在的卡片上。雖然它不是UML的組成部分,但也是一種快捷有效的的OO設(shè)計(jì)技術(shù)。直接建模(繪制順序圖)同理。第七十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二2.對(duì)象交互建模交互模型的設(shè)計(jì)內(nèi)容:對(duì)象職責(zé)的識(shí)別,意味著對(duì)象協(xié)作過(guò)程中消息的分發(fā)定義消息的完整格式將消息映射為類的操作,并在實(shí)現(xiàn)時(shí)轉(zhuǎn)化為類的方法第七十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二3.消息的設(shè)計(jì)消息規(guī)范化設(shè)計(jì),需要使用以下表達(dá)式語(yǔ)法:return:=message(parameter:parameterType):returnType如果類型信息非常明顯或不重要的話,可以省略書(shū)寫(xiě),如:reader:=getReader(cardID:String)消息的序號(hào)消息的次序用自小到大的順序號(hào)來(lái)表示。按照消息的完成情況,消息可以有嵌套消息(代表任務(wù)分解)。嵌套消息的序號(hào)按照層次編號(hào),所有嵌套的子消息都是服務(wù)于其上層消息。第七十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二嵌套消息嵌套消息含義與結(jié)構(gòu)化方法中的模塊調(diào)用相同結(jié)構(gòu)化方法中模塊都是單個(gè)的,沒(méi)有分組。面向?qū)ο蠓椒ㄒ矎?qiáng)調(diào)模塊的概念,但模塊都有一個(gè)主人——對(duì)象OOD中的模塊劃分要解決兩個(gè)問(wèn)題:任務(wù)如何分解為子任務(wù)?各個(gè)任務(wù)應(yīng)由誰(shuí)承擔(dān)?第七十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二嵌套消息示例計(jì)算超期罰金,最高不超過(guò)書(shū)價(jià)Loan對(duì)象在計(jì)算超期罰金時(shí)還需要獲取資源的價(jià)格和罰金標(biāo)準(zhǔn),因此向ResourceItem發(fā)送請(qǐng)求價(jià)格的消息,向FineRule發(fā)送超期罰金標(biāo)準(zhǔn),而ResourceItem對(duì)象并不記錄價(jià)格,因此請(qǐng)求價(jià)格的消息還需要發(fā)送給ResourceTitle對(duì)象。第七十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二嵌套消息示例代碼Loan::getTotalFine():double{ titlePrice=itemObject.getTitlePrice(); finePerDay=fineObject.getOverDueFine();

doublefineAmount=finePerDay*(this.returnDate–this.dueDate); if(fineAmount<titlePrice) returnfineAmount; else returntitlePrice;}ResourceItem::getTitlePrice():double{ returnitsTitleObject.getPrice();}第七十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二返回消息很多消息發(fā)送之后,消息的接收對(duì)象會(huì)在響應(yīng)后產(chǎn)生一些結(jié)果回傳給發(fā)送者,這就是返回消息。在UML交互圖中,返回消息以虛線箭頭線表示。為了簡(jiǎn)潔,一般省略返回消息。第七十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二自身消息有些消息是對(duì)象發(fā)給自己的。比如借書(shū)界面中要增加一個(gè)借閱項(xiàng)目,首先發(fā)送消息給控制類請(qǐng)求業(yè)務(wù)邏輯的處理(makeNewLoan消息),然后在窗口的列表中將新的借閱記錄添加進(jìn)來(lái)(addListItem)以備瀏覽和打印,添加列表的功能是界面類的職責(zé),消息應(yīng)發(fā)給窗口對(duì)象自身通常是一個(gè)類內(nèi)部的private方法第七十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二兩類特殊的消息對(duì)象創(chuàng)建UML中使用create消息表示對(duì)象實(shí)例化和初始化。例如,在C#和Java中,使用new操作符接構(gòu)造函數(shù)的調(diào)用方式來(lái)實(shí)現(xiàn)實(shí)例的自動(dòng)分配和初始化。常在設(shè)計(jì)類圖中忽略相關(guān)的方法。屬性存取在某些語(yǔ)言中,所有屬性都聲明為私有的,因此需要發(fā)送消息實(shí)現(xiàn)屬性的存取。例如getPrice和setPrice。為了模型的簡(jiǎn)潔,有時(shí)也省略這些消息,但在類圖中可以通過(guò)屬性的可見(jiàn)性來(lái)明確它們是否存在。第七十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館系統(tǒng)的借書(shū)界面第七十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館順序圖1借書(shū)(分析階段,消息使用中文)第八十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二設(shè)計(jì)階段——圖書(shū)館順序圖示例loop借書(shū)(消息對(duì)應(yīng)為類的方法)第八十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館系統(tǒng)的還書(shū)界面第八十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館順序圖2還書(shū)(備選事件流使用opt框架,表示可選分支):loop第八十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二圖書(shū)館順序圖2還書(shū)(主事件流,簡(jiǎn)單的備選事件流可以畫(huà)在一張圖上,復(fù)雜的備選事件流可以另畫(huà)一張順序圖)loop第八十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二4.為類添加方法對(duì)象職責(zé)體現(xiàn)為順序圖中類所收到的消息,也就是類的方法。類的方法可以定義可見(jiàn)性,當(dāng)然順序圖中的絕大多數(shù)消息是公有方法。第八十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二實(shí)體類的方法類圖(包含屬性和方法):第八十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.3.5設(shè)計(jì)類的關(guān)系設(shè)計(jì)四種關(guān)系的具體實(shí)現(xiàn):泛化(類)關(guān)聯(lián)(對(duì)象)實(shí)現(xiàn)(類)依賴(對(duì)象)第八十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二1.泛化設(shè)計(jì)泛化在面向?qū)ο笳Z(yǔ)言中使用繼承來(lái)實(shí)現(xiàn),繼承機(jī)制實(shí)現(xiàn)了子類擁有父類特性的這一過(guò)程。泛化設(shè)計(jì)還有一個(gè)更重要的目的在于如何實(shí)現(xiàn)多態(tài)性。第八十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二2.關(guān)聯(lián)設(shè)計(jì)實(shí)現(xiàn)對(duì)象關(guān)聯(lián)的一個(gè)簡(jiǎn)單策略就是:在關(guān)聯(lián)的源類中聲明一個(gè)屬性來(lái)保存對(duì)目標(biāo)類的實(shí)例的引用,這種屬性稱為關(guān)聯(lián)屬性或引用屬性。根據(jù)關(guān)聯(lián)的導(dǎo)航性,有單向關(guān)聯(lián)和雙向關(guān)聯(lián)。根據(jù)關(guān)聯(lián)重?cái)?shù),有一對(duì)一、一對(duì)多和多對(duì)多關(guān)聯(lián),多對(duì)多關(guān)聯(lián)通過(guò)建立關(guān)聯(lián)類分解成1對(duì)多的關(guān)聯(lián)。限定關(guān)聯(lián)。第八十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二單向關(guān)聯(lián)//實(shí)現(xiàn)代碼對(duì)照:publicclassResourceTitle{ privateReservationr1; privateMapitems=newHaspMap();

…}第九十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二重?cái)?shù)為0..1的關(guān)聯(lián)對(duì)于可選關(guān)聯(lián),源對(duì)象雖然定義了目標(biāo)對(duì)象,但目標(biāo)對(duì)象可能為空值(通常為null值),意味著沒(méi)有關(guān)聯(lián)對(duì)象。如某種書(shū)當(dāng)前不存在預(yù)定記錄。關(guān)聯(lián)屬性的值可以在源對(duì)象的構(gòu)造函數(shù)中被創(chuàng)建,也可能在運(yùn)行過(guò)程中通過(guò)方法賦值。publicclassResourceTitle{ privateReservationtheReserve; //關(guān)聯(lián)屬性

publicReservationgetReservation(){//獲取關(guān)聯(lián)對(duì)象

returntheReserve; } publicvoidsetReservation(Reservationrs){ theReserve=rs; }}第九十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二重?cái)?shù)為多的關(guān)聯(lián)對(duì)于重?cái)?shù)為多的關(guān)聯(lián),源對(duì)象應(yīng)該能夠管理多個(gè)目標(biāo)對(duì)象。實(shí)現(xiàn)這種關(guān)聯(lián)最簡(jiǎn)單的方法是使用開(kāi)發(fā)語(yǔ)言提供的類庫(kù)中的容器類來(lái)保存多個(gè)對(duì)象引用,如Map、List類等。示例代碼如下:publicclassResourceTitle{ privateMapitems=newHaspMap(); //集合關(guān)聯(lián)屬性

publicvoidaddItem(StringitemID){ //對(duì)象也可作參數(shù)

ResourceItemaCopy=newResourceItem(itemID); items.put(itemID,aCopy); } publicvoidremoveItem(StringitemID){ items.remove(itemID); }}第九十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二雙向關(guān)聯(lián)當(dāng)關(guān)聯(lián)雙方需要相互都能訪問(wèn)到對(duì)方時(shí),就是雙向關(guān)聯(lián)。比如Loan能知道所借的是哪一個(gè)ResourceItem,并且ResourceItem能夠訪問(wèn)到對(duì)應(yīng)的Loan。具體實(shí)現(xiàn)有多種辦法,以下代碼是一種示例。publicclassResourceItem{ privateLoantheLoan; //關(guān)聯(lián)屬性

publicvoidaddLoan(Loanloan){ //建立雙向關(guān)聯(lián)

theLoan=newLoan(this); }

……}publicclassLoan{ privateResourceItemtheItem; //關(guān)聯(lián)屬性

publicLoan(ResourceItemr){ //Loan的構(gòu)造函數(shù)

theItem=r; //建立和ResourceItem的關(guān)聯(lián)

}

……}第九十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二關(guān)聯(lián)的創(chuàng)建或解除關(guān)聯(lián)可以在對(duì)象一產(chǎn)生就已經(jīng)存在,也可以在運(yùn)行期間動(dòng)態(tài)建立。對(duì)于那些比較持久并且不會(huì)發(fā)生變化的關(guān)聯(lián),或者具有很強(qiáng)歸屬關(guān)系的聚集關(guān)聯(lián),一般在主對(duì)象的構(gòu)造函數(shù)中創(chuàng)建關(guān)聯(lián)對(duì)象或記錄下關(guān)聯(lián)對(duì)象的引用較為松散的對(duì)象關(guān)聯(lián),一般當(dāng)某項(xiàng)業(yè)務(wù)邏輯發(fā)生時(shí),兩個(gè)對(duì)象的關(guān)聯(lián)才被確立,可以設(shè)計(jì)特定方法建立或解除關(guān)聯(lián)。第九十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二動(dòng)態(tài)創(chuàng)建關(guān)聯(lián)舉例publicClassCar

privateDrivertheDriver;

…… publicvoidassignDriver(Driverdr){theDriver=dr }}Carc1=newCar(“京B58888”,“紅旗”);Driverd1=NewDriver("Wang");Driverd2

=NewDriver("Zhao");c1.assignDriver(d1); //建立c1和d1之間的關(guān)聯(lián)……c1.assignDriver(d2); //建立c1和d2之間的關(guān)聯(lián),c1和d1的關(guān)聯(lián)被解除第九十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二3.接口與實(shí)現(xiàn)的設(shè)計(jì)所有的實(shí)體類都具有這些數(shù)據(jù)庫(kù)操作行為,將這些操作抽象出來(lái)封裝到一個(gè)IEntityOperate接口中public

interface

IEntityOperate{

int

InsertEntity(); //插入對(duì)象數(shù)據(jù)到數(shù)據(jù)庫(kù)中int

UpdateEntity(); //更新對(duì)象數(shù)據(jù)到數(shù)據(jù)庫(kù)中

int

DeleteEntity(); //刪除數(shù)據(jù)庫(kù)中指定對(duì)象數(shù)據(jù)}第九十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二4.依賴設(shè)計(jì)在類圖中依賴關(guān)系通常指明一個(gè)類的對(duì)象實(shí)例使用了另一個(gè)類的屬性和方法。界面層使用了控制層對(duì)象,控制層對(duì)象使用了數(shù)據(jù)訪問(wèn)層對(duì)象。第九十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二類的耦合類之間的聯(lián)系的緊密程度就是類之間的耦合度。四種關(guān)系的耦合程度從高至低:泛化實(shí)現(xiàn)關(guān)聯(lián)依賴(上層對(duì)象依賴于下層對(duì)象)第九十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二類的內(nèi)聚類的合理封裝內(nèi)部屬性和方法的關(guān)系緊密單一職責(zé)的類不要雜湊類不要大而全的類第九十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.4對(duì)象持久化與數(shù)據(jù)庫(kù)軟件中的對(duì)象在程序中定義的對(duì)象,在系統(tǒng)運(yùn)行期間其生命周期包含創(chuàng)建、使用和消亡三個(gè)階段。因?yàn)槌绦蛩写a和數(shù)據(jù)在運(yùn)行時(shí)載入到內(nèi)存,程序運(yùn)行結(jié)束它們都要從內(nèi)存中釋放,所以這些對(duì)象實(shí)例都是瞬時(shí)的或暫時(shí)性的。信息系統(tǒng)中的對(duì)象一個(gè)信息系統(tǒng)中的領(lǐng)域類指代了系統(tǒng)中有意義的事物,這些領(lǐng)域?qū)ο蠹捌渌休d的信息是長(zhǎng)期的,甚至是永久的。這些持久對(duì)象就是指生存期可以超越軟件的一次執(zhí)行時(shí)間而長(zhǎng)期存在的對(duì)象。軟件對(duì)象如何持久化?第一百頁(yè),共一百五十一頁(yè),編輯于2023年,星期二持久化對(duì)象持久對(duì)象就是指生存期可以超越程序的任意一次執(zhí)行時(shí)間而長(zhǎng)期存在的對(duì)象。比如新建了一名讀者對(duì)象,程序結(jié)束后該讀者的基本信息將轉(zhuǎn)化為持久保存的讀者數(shù)據(jù),這個(gè)過(guò)程也是通常所說(shuō)的“物化”。反過(guò)來(lái),持久后的數(shù)據(jù)需要取出并重新生成對(duì)象,這個(gè)過(guò)程稱為“反物化”。通常實(shí)體對(duì)象都會(huì)成為持久對(duì)象,實(shí)體類也稱為持久類。第一百零一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.4.1幾種持久化方案文件從文件查詢有關(guān)數(shù)據(jù)來(lái)初始化對(duì)象或創(chuàng)建一個(gè)新對(duì)象。對(duì)象發(fā)生改變或需要保存,則將對(duì)象數(shù)據(jù)寫(xiě)入到文件中(如XML文件)。但復(fù)雜靈活的數(shù)據(jù)存取和查詢難以實(shí)現(xiàn)。面向?qū)ο髷?shù)據(jù)庫(kù)管理系統(tǒng)(OODBMS)一種理想的基于存儲(chǔ)和管理永久對(duì)象的對(duì)象管理系統(tǒng),只要程序員聲明某個(gè)對(duì)象是永久的,OODBMS中數(shù)據(jù)庫(kù)模型和對(duì)象模型一致。對(duì)象的存儲(chǔ)、恢復(fù)、轉(zhuǎn)換等問(wèn)題由OODBMS自動(dòng)解決。但目前尚未達(dá)到廣泛應(yīng)用的階段。成熟的關(guān)系型數(shù)據(jù)庫(kù)系統(tǒng)(RDBMS)關(guān)系型數(shù)據(jù)庫(kù)以二維表中的一條記錄來(lái)保存某個(gè)對(duì)象,記錄的字段對(duì)應(yīng)對(duì)象屬性,繼承關(guān)系或關(guān)聯(lián)關(guān)系通過(guò)表之間的聯(lián)系表現(xiàn)。對(duì)象與關(guān)系兩個(gè)概念之間存在“阻抗”,因此需要進(jìn)行映射。該方案是目前最普及的選擇。其他的存儲(chǔ)機(jī)制還有層次數(shù)據(jù)庫(kù)、網(wǎng)狀數(shù)據(jù)庫(kù)等等第一百零二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二持久化設(shè)計(jì)的步驟確定持久類及其持久屬性確定持久化方案設(shè)計(jì)XML文件模式(Schema)或設(shè)計(jì)關(guān)系數(shù)據(jù)庫(kù)的模型根據(jù)持久化方案設(shè)計(jì)持久化方法或持久化組件第一百零三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二關(guān)系型數(shù)據(jù)庫(kù)的持久化方案在確定持久類及其持久屬性之后,還要解決以下問(wèn)題:實(shí)體類如何對(duì)應(yīng)到關(guān)系中的表呢?類的繼承關(guān)系和對(duì)象關(guān)聯(lián)如何體現(xiàn)?關(guān)系數(shù)據(jù)庫(kù)的操作總結(jié)起來(lái)就是CRUD操作:創(chuàng)建記錄(Create)、查詢記錄(Retrieve)、修改記錄(Update)和刪除記錄(Delete),這些操作應(yīng)該由誰(shuí)來(lái)實(shí)現(xiàn)?什么時(shí)候使用?對(duì)象實(shí)例是內(nèi)存的一個(gè)單元,使用實(shí)例名來(lái)標(biāo)識(shí),表中的記錄則采用唯一的主鍵碼來(lái)識(shí)別,如何實(shí)現(xiàn)特定對(duì)象實(shí)例和記錄的一一對(duì)應(yīng)呢?第一百零四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.4.2ORM設(shè)計(jì)問(wèn)題無(wú)論自己編寫(xiě)代碼實(shí)現(xiàn)持久化,還是使用持久化組件,都要解決一個(gè)問(wèn)題,那就是:對(duì)象與數(shù)據(jù)庫(kù)的映射關(guān)系。采用關(guān)系型數(shù)據(jù)庫(kù)實(shí)現(xiàn)對(duì)象的數(shù)據(jù)存儲(chǔ),這種映射也稱為對(duì)象-關(guān)系映射ORM(ObjectRelationalMapping)。ORM的設(shè)計(jì)包括:確定對(duì)象和表的映射關(guān)系確定軟件實(shí)現(xiàn)構(gòu)架第一百零五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二1、對(duì)象-關(guān)系的映射類映射到表關(guān)聯(lián)關(guān)系的映射繼承關(guān)系的映射第一百零六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二持久類映射到表在一個(gè)第三范式的關(guān)系數(shù)據(jù)庫(kù)中,表中每一行(每個(gè)“元組”)都被認(rèn)為是一個(gè)對(duì)象。表中的列則對(duì)應(yīng)于持久類的持久屬性(注意:持久類也可能有臨時(shí)屬性)。在沒(méi)有其他關(guān)聯(lián)類的簡(jiǎn)單情況下,這兩種模型間的映射將會(huì)很簡(jiǎn)單。類的屬性對(duì)應(yīng)于列,其數(shù)據(jù)類型轉(zhuǎn)換為列允許的數(shù)據(jù)類型之一。

第一百零七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二關(guān)聯(lián)關(guān)系的映射兩個(gè)持久對(duì)象間的關(guān)聯(lián)關(guān)系在OOAD中通常表現(xiàn)為一個(gè)對(duì)象存放了另一個(gè)對(duì)象的對(duì)象引用(也稱為關(guān)聯(lián)屬性),而在表中則表現(xiàn)為外鍵。外鍵是一個(gè)表中的一列,其中存放所關(guān)聯(lián)對(duì)象的主鍵值。對(duì)于對(duì)象關(guān)聯(lián)中的特殊類型——組成聚集,因?yàn)檎w對(duì)象和部分對(duì)象具有相同的生存周期,因此為了在數(shù)據(jù)模型中實(shí)現(xiàn)引用完整性,數(shù)據(jù)庫(kù)詳細(xì)設(shè)計(jì)時(shí)還需要實(shí)施刪除約束,比如刪除圖書(shū)館某個(gè)資源品種就必須同時(shí)刪除所有的資源項(xiàng)。以及參照完整性的設(shè)計(jì)第一百零八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二ReaderLoan借閱1*讀者:

讀者編號(hào),讀者姓名,讀者單位,當(dāng)前限額借書(shū)記錄:

ID,讀者編號(hào),館藏流水號(hào),借書(shū)日期,到期日期,歸還日期館藏項(xiàng):館藏流水號(hào),當(dāng)前狀態(tài)ResourceItem0..11記載第一百零九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二繼承關(guān)系的映射

三種可選方式:繼承關(guān)系樹(shù)的每個(gè)類對(duì)應(yīng)一個(gè)表:使用不同的表來(lái)分別表示父類和子類。繼承關(guān)系樹(shù)的每個(gè)具體類對(duì)應(yīng)一個(gè)表:將所有父類的屬性復(fù)制為子類表中不同的列,父類不建立對(duì)應(yīng)的表。繼承關(guān)系樹(shù)只對(duì)應(yīng)一個(gè)表:使用一張表來(lái)描述父類和所有子類的屬性,額外還需要增加一個(gè)列表示對(duì)象所屬的子類型。第一百一十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二BookDiscResourceTitle1、三個(gè)表:品種:ISBN,名稱,作者,出版日期,價(jià)格…書(shū)籍:ISBN,開(kāi)本光盤:ISBN,光盤類型,盤片數(shù)量2、兩個(gè)表:書(shū)籍:ISBN,名稱,作者…,開(kāi)本光盤:ISBN,名稱,作者…,光盤類型,盤片數(shù)量3、一個(gè)表品種:ISBN,名稱,作者…,品種類別,開(kāi)本,光盤類型,盤片數(shù)量第一百一十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二2、持久化軟件架構(gòu)設(shè)計(jì)(1)在領(lǐng)域?qū)訉?shí)現(xiàn),即直接在實(shí)體類中編寫(xiě)SQL語(yǔ)句訪問(wèn)數(shù)據(jù)庫(kù),或者為了減少數(shù)據(jù)庫(kù)操作的代碼數(shù)量,編寫(xiě)一個(gè)公用的數(shù)據(jù)訪問(wèn)類,各實(shí)體類將組裝好的SQL語(yǔ)句傳遞給該類以實(shí)現(xiàn)數(shù)據(jù)庫(kù)訪問(wèn)。(2)設(shè)計(jì)簡(jiǎn)單的數(shù)據(jù)映射層實(shí)現(xiàn)數(shù)據(jù)訪問(wèn),即把SQL訪問(wèn)從業(yè)務(wù)邏輯中分離出來(lái),放到獨(dú)立的類中。當(dāng)每個(gè)實(shí)體類映射為一張表時(shí),可以為每個(gè)實(shí)體類建立一個(gè)數(shù)據(jù)訪問(wèn)類,一般包括數(shù)據(jù)查找方法以及更新、插入和刪除方法。(3)設(shè)計(jì)功能獨(dú)立具有數(shù)據(jù)映射器的持久層。業(yè)務(wù)邏輯層完全不用了解數(shù)據(jù)的存儲(chǔ),應(yīng)用程序中的對(duì)象通過(guò)設(shè)置與表的映射關(guān)系后,可以在開(kāi)發(fā)人員對(duì)底層數(shù)據(jù)庫(kù)及其模型毫不知情的情況下實(shí)現(xiàn)數(shù)據(jù)的持久化。映射關(guān)系通過(guò)數(shù)據(jù)映射器來(lái)具體實(shí)施,它是分離內(nèi)存對(duì)象和數(shù)據(jù)庫(kù)的一個(gè)軟件層,其職責(zé)是在內(nèi)存對(duì)象和數(shù)據(jù)庫(kù)之間傳遞數(shù)據(jù)并保持它們彼此獨(dú)立。第一百一十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二三種設(shè)計(jì)方法的舉例參見(jiàn)用戶權(quán)限的VB程序,實(shí)體類負(fù)責(zé)數(shù)據(jù)庫(kù)的訪問(wèn)參見(jiàn)微軟PetShop程序,數(shù)據(jù)庫(kù)訪問(wèn)通過(guò)編寫(xiě)數(shù)據(jù)訪問(wèn)層的類來(lái)實(shí)現(xiàn)。比如業(yè)務(wù)層的類Order,有Insert、getOrder方法分別完成保存和查詢的功能,這些方法中使用了數(shù)據(jù)訪問(wèn)層的類來(lái)讀寫(xiě)數(shù)據(jù)庫(kù)網(wǎng)上可查閱Hibernate示例程序,代碼中不需要編寫(xiě)SQL語(yǔ)句第一百一十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.5設(shè)計(jì)原則總的原則抽象與復(fù)用(封裝、信息隱藏)松耦合面向功能模塊設(shè)計(jì)功能內(nèi)聚的模塊,避免使用全局?jǐn)?shù)據(jù)模塊傳遞的參數(shù)作數(shù)據(jù)用,并且盡可能少模塊內(nèi)語(yǔ)句數(shù)一般為50-100面向?qū)ο髥我宦氊?zé)、開(kāi)放封閉、里氏替換、依賴倒置…面向服務(wù)標(biāo)準(zhǔn)化服務(wù)合約、服務(wù)松散耦合、服務(wù)抽象、服務(wù)可復(fù)用、服務(wù)自治、服務(wù)無(wú)狀態(tài)、服務(wù)可發(fā)現(xiàn)性和服務(wù)可組合性第一百一十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.5.1抽象與復(fù)用模塊化:模塊是廣泛意義上的建模元素,可以是子過(guò)程或函數(shù)、類、構(gòu)件、服務(wù)、流程等。模塊化強(qiáng)調(diào)抽象和封裝。好的抽象能讓人們集中精力考慮問(wèn)題實(shí)質(zhì),而忽略問(wèn)題中與主旨無(wú)關(guān)的次要部分。好的封裝能讓一個(gè)部件暴露出其最本質(zhì)的內(nèi)容,讓人們快速理解和使用它,不讓復(fù)雜性蔓延。模塊化的另一個(gè)好處就是復(fù)用。不同業(yè)務(wù)流程中重復(fù)對(duì)一組數(shù)據(jù)執(zhí)行同一操作,對(duì)這類數(shù)據(jù)和操作進(jìn)行合理抽象和封裝后,就能在多個(gè)地方進(jìn)行復(fù)用,節(jié)約了成本,提高了效率。第一百一十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.5.2松耦合任何事物只要相互之間存在某種關(guān)系,就意味著事物間的耦合。緊耦合:是指應(yīng)用系統(tǒng)的各部件在功能上、數(shù)據(jù)上或結(jié)構(gòu)上是緊密相連的,因而每當(dāng)某個(gè)部件發(fā)生變化時(shí),相關(guān)部分的也要隨之進(jìn)行部分甚至整個(gè)應(yīng)用程序的調(diào)整。松耦合:面對(duì)變化則具有很好的適應(yīng)能力和應(yīng)變能力。耦合和內(nèi)聚有著密切關(guān)系,通常高內(nèi)聚就會(huì)帶來(lái)松耦合。第一百一十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.5.3單一職責(zé)原則SRP即內(nèi)聚性原則。單一職責(zé)的模塊—>單一職責(zé)的類。一個(gè)類承擔(dān)的職責(zé)過(guò)多,某個(gè)職責(zé)的變化可能會(huì)削弱或者抑制該類完成其他職責(zé)的能力,并影響到構(gòu)建、測(cè)試和部署等活動(dòng)。多職責(zé)會(huì)導(dǎo)致脆弱的和不易理解的設(shè)計(jì)。職責(zé)過(guò)多的職工類第一百一十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二分離職責(zé)到不同的類對(duì)“雜湊類”進(jìn)行分解第一百一十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.5.4開(kāi)放封閉原則OCP軟件實(shí)體(類、模塊、函數(shù)等)應(yīng)該是“可擴(kuò)展”的,但又是“不可修改”的?!白兓攀遣蛔兊恼胬怼?,但通過(guò)設(shè)計(jì)使得系統(tǒng)能夠適應(yīng)改變又能保持相對(duì)穩(wěn)定,避免僵化的設(shè)計(jì)。開(kāi)放-封閉原則實(shí)現(xiàn)兩個(gè)目標(biāo):“對(duì)于擴(kuò)展是開(kāi)放的”(openforextension)。這意味著模塊的行為是可擴(kuò)展的,從而使其具有滿足那些改變的新需求?!皩?duì)于更改是封閉的”(closedformodification)。當(dāng)對(duì)模塊進(jìn)行擴(kuò)展時(shí),不必改動(dòng)模塊的源代碼或二進(jìn)制代碼(如dll/jar文件)。自相矛盾嗎?第一百一十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二什么是不封閉、不開(kāi)放如下的模型可以處理月薪制(SALARIED)和時(shí)薪制(WAGED)職工工資,時(shí)薪制根據(jù)考勤卡計(jì)算。如果增加了一種新的職工類型,其計(jì)酬方式不同(如提成制),則必定要修改Employee類(即Employee是不封閉的),如果讓其封閉,開(kāi)放擴(kuò)展又是不可能的。第一百二十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二如何改進(jìn)利用抽象機(jī)制封閉:Employee及其已有的子類是封閉的,不可改開(kāi)放:可以派生新的子類,實(shí)現(xiàn)新的需求,可擴(kuò)展第一百二十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.5.5Liscov替換原則LSP實(shí)現(xiàn)OCP的主要機(jī)制是抽象和多態(tài)。怎樣設(shè)計(jì)最佳的繼承層次,BarbaraLiskov在1988年首次提出LSP:子類型(subtype)必須能夠替換掉它們的基類型(basetype)。假設(shè)S是T的子類型,所有使用了T對(duì)象的程序(也稱客戶程序),用S對(duì)象替換T對(duì)象后,仍能成功執(zhí)行。LSP是多態(tài)順利實(shí)現(xiàn)的保證,從而使OCP成為可能。因?yàn)檎亲宇愋偷目商鎿Q性才使得使用基類的模塊在無(wú)需修改的情況下就可以擴(kuò)展。增加或修改任何一個(gè)子類型,基類不用修改(封閉)基類的使用者(客戶程序)通過(guò)多態(tài)得到擴(kuò)展或修改過(guò)的行為(開(kāi)放)。第一百二十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二一個(gè)使用繼承的例子正方形是長(zhǎng)方形的一種特例第一百二十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二會(huì)發(fā)生什么情況?正方形有獨(dú)特的行為方式通過(guò)覆蓋父類的有關(guān)方法來(lái)實(shí)現(xiàn)子類行為第一百二十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二客戶程序如何能了解長(zhǎng)方形的使用者按照長(zhǎng)方形的特點(diǎn)來(lái)調(diào)用SetWidth和SetHeight兩個(gè)函數(shù),并測(cè)試面積,代碼如下:voidtestArea(Rectangle&r){ r.SetWidth(5); r.SetHeight(4); assert(r.Area()==20);}如果傳遞進(jìn)來(lái)的是Square對(duì)象又會(huì)如何呢?顯然會(huì)出現(xiàn)斷言錯(cuò)誤,測(cè)試失敗。對(duì)于客戶程序來(lái)說(shuō),模型中的層次結(jié)構(gòu)是脆弱的,因?yàn)檫`反了LSP替換原則,Square對(duì)象和Rectangle對(duì)象的行為方式不相容,這樣的抽象即使采用虛函數(shù)也無(wú)法實(shí)現(xiàn)子類對(duì)父類的替換。違反LSP替換原則,多態(tài)的使用是不安全的。第一百二十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.5.6依賴倒置原則DIP高層模塊不應(yīng)該依賴于低層模塊,二者都應(yīng)該依賴于抽象(也稱針對(duì)抽象編程);抽象不應(yīng)該依賴于細(xì)節(jié),細(xì)節(jié)應(yīng)該依賴于抽象。結(jié)構(gòu)化設(shè)計(jì)時(shí),高層模塊總是依賴于低層模塊。面向?qū)ο蟮姆謱幽J街幸彩歉邔拥念愐蕾囉诘讓拥念悺0凑兆陨隙碌囊蕾囮P(guān)系,高層的策略設(shè)置模塊往往是無(wú)法重用的,如果設(shè)法讓高層模塊獨(dú)立于低層模塊,則實(shí)現(xiàn)重用就變?yōu)榭赡?。依賴倒置原則的啟發(fā)式建議是“依賴于抽象”,具體做法是將高層需要的服務(wù)聲明為抽象接口,高層使用這些接口,低層模塊實(shí)現(xiàn)這些接口,使得高層不再依賴于低層,而是依賴于抽象接口,同樣低層也依賴于抽象接口。第一百二十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二傳統(tǒng)的依賴層次高層使用低層的對(duì)象及其服務(wù)第一百二十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二都依賴于抽象設(shè)計(jì)抽象接口,上層類使用接口,下層類實(shí)現(xiàn)接口這樣Button類也可以得到重用,也許是開(kāi)關(guān)燈,也許是開(kāi)關(guān)電視,根據(jù)創(chuàng)建具體對(duì)象完成多態(tài)的行為。第一百二十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二如何遵守設(shè)計(jì)原則設(shè)計(jì)原則不是死記硬背,而是要靈活運(yùn)用一些成熟的設(shè)計(jì)模式可以幫助我們解決實(shí)際問(wèn)題,并且符合設(shè)計(jì)原則第一百二十九頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.6軟件設(shè)計(jì)模式GRASP對(duì)象職責(zé)分配模式GRASP(GeneralResponsibilityAssignmentSoftwarePattern)是一組通用的基本原則和慣用的設(shè)計(jì)方案,用來(lái)指導(dǎo)對(duì)象職責(zé)的分配和交互圖的創(chuàng)建。OOAD經(jīng)典著作《UML和模式應(yīng)用》進(jìn)行了總結(jié)和應(yīng)用。GoF23種設(shè)計(jì)模式由四人組的專著《設(shè)計(jì)模式》一書(shū)總結(jié)了廣為應(yīng)用的23種設(shè)計(jì)模式,每種模式解決了一個(gè)特定問(wèn)題,包括一組合適的對(duì)象和對(duì)象接口,以及對(duì)象間協(xié)作的方式。第一百三十頁(yè),共一百五十一頁(yè),編輯于2023年,星期二模式無(wú)處不在好萊塢電影模式社會(huì)題材、動(dòng)作片、言情片、歷史題材片…中國(guó)象棋開(kāi)局當(dāng)頭炮、順炮、列炮、屏風(fēng)馬…圍棋布局星小目、三連星、中國(guó)流、宇宙流…古代行軍布陣八陣圖、天門陣、一字長(zhǎng)蛇陣…建筑、服裝、交通、社會(huì)、文化…諸多模式模式是對(duì)成功應(yīng)用經(jīng)驗(yàn)的總結(jié)與復(fù)用第一百三十一頁(yè),共一百五十一頁(yè),編輯于2023年,星期二設(shè)計(jì)模式的基本思想-1軟件是在不斷進(jìn)化的需求在不斷改變,所以軟件應(yīng)該適應(yīng)變化設(shè)計(jì)模式是為了讓軟件更加適應(yīng)變化,有更多的可復(fù)用性;就是有變化時(shí)你不用從頭重寫(xiě)一次這個(gè)軟件如何適應(yīng)變化?就應(yīng)該封裝變化,讓變化的影響最小封裝復(fù)雜性,提供簡(jiǎn)單的接口第一百三十二頁(yè),共一百五十一頁(yè),編輯于2023年,星期二設(shè)計(jì)模式的基本思想-2遵守上述設(shè)計(jì)原則:松耦合針對(duì)接口編程,而不是針對(duì)實(shí)現(xiàn)編程使用繼承、組合、委托、多態(tài)、泛型第一百三十三頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.6.1什么是設(shè)計(jì)模式美國(guó)建筑設(shè)計(jì)大師ChristopherAlexander,在他出版的一本關(guān)于城市規(guī)劃和建筑設(shè)計(jì)的著作《建筑的永恒方法》中,是這樣描述模式的:模式是一條由三部分組成的規(guī)則,它表示了一個(gè)特定環(huán)境、一個(gè)問(wèn)題和一個(gè)解決方案之間的關(guān)系。每一個(gè)模式描述了一個(gè)在我們周圍不斷重復(fù)發(fā)生的問(wèn)題以及該問(wèn)題解決方案的核心內(nèi)容。這樣,你就能一次又一次地使用該方案而不必做重復(fù)勞動(dòng)。Eachpatterndescribesaproblemwhichoccursoverandoveragaininourenvironments,andthendescribesthecoreofthesolutiontothatproblem,insuchawaythatyoucanusethissolutionamilliontimesover,withouteverdoingitthesamewaytwice. --ChristopherAlexander,

APatternLanguage,1977第一百三十四頁(yè),共一百五十一頁(yè),編輯于2023年,星期二設(shè)計(jì)模式名成為專業(yè)詞匯討論設(shè)計(jì)方案時(shí),使用模式名能簡(jiǎn)化描述第一百三十五頁(yè),共一百五十一頁(yè),編輯于2023年,星期二設(shè)計(jì)模式是:優(yōu)秀的設(shè)計(jì)范例從優(yōu)秀設(shè)計(jì)方案中發(fā)現(xiàn)和總結(jié)出來(lái)的經(jīng)驗(yàn)在實(shí)踐中反復(fù)出現(xiàn)的設(shè)計(jì)問(wèn)題的優(yōu)秀解決方案設(shè)計(jì)者相互交流的基本術(shù)語(yǔ):設(shè)計(jì)語(yǔ)言培養(yǎng)優(yōu)秀設(shè)計(jì)師的一條捷徑不是:面向?qū)ο笤O(shè)計(jì)的框架可供簡(jiǎn)單組合的設(shè)計(jì)元件發(fā)明創(chuàng)造出來(lái)的創(chuàng)新思路解決面向?qū)ο笤O(shè)計(jì)問(wèn)題的完整方案第一百三十六頁(yè),共一百五十一頁(yè),編輯于2023年,星期二設(shè)計(jì)模式的基本要素名稱:用于助記,形象表示這個(gè)模式問(wèn)題:這個(gè)模式可以解決什么問(wèn)題解決方案:這個(gè)模式怎樣解決這個(gè)問(wèn)題的步驟與方法效果:使用這個(gè)模式與不使用這個(gè)模式有什么區(qū)別,它有什么優(yōu)點(diǎn)和缺點(diǎn)一個(gè)問(wèn)題可以有多種解法,好的解法都可以找到很多種,每種都有優(yōu)缺點(diǎn),某個(gè)模式也不一定永遠(yuǎn)是最好的第一百三十七頁(yè),共一百五十一頁(yè),編輯于2023年,星期二11.6.2GoF設(shè)計(jì)模式GangofFour,簡(jiǎn)稱GoF,他們是:ErichGammaRichardHelmRalphJohnsonJohnVlissides(2005年底去世)著作《設(shè)計(jì)模式》第一百三十八頁(yè),共一百五十一頁(yè),編輯于2023年,星期二23種GoF模式創(chuàng)建型結(jié)構(gòu)型行為型類FactoryMethod

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論