多媒體-第三講-時序圖 (2)課件_第1頁
多媒體-第三講-時序圖 (2)課件_第2頁
多媒體-第三講-時序圖 (2)課件_第3頁
多媒體-第三講-時序圖 (2)課件_第4頁
多媒體-第三講-時序圖 (2)課件_第5頁
已閱讀5頁,還剩20頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

面向?qū)ο蟮姆治雠c設(shè)計課程學(xué)習(xí)的內(nèi)容OO設(shè)計原則UML設(shè)計圖及RoseRational工具OO設(shè)計模式典型項目的分析與設(shè)計學(xué)習(xí)方法掌握主要OO原則的原理和應(yīng)用要點改變java編程習(xí)慣學(xué)會設(shè)計Rational工具的使用;掌握類圖、用例圖、順序圖、活動圖的設(shè)計熟練掌握MVC設(shè)計方法熟練掌握數(shù)據(jù)庫編程深化了解API,深化基于API的編程反復(fù)實踐典型模式應(yīng)用于項目的分析和設(shè)計考核基于典型項目的考察:項目的分析與方案設(shè)計UML典型圖項目代碼中基本原則的應(yīng)用項目設(shè)計中模型的使用OOP編程要點

OOP追求的目標(biāo):可用性、完整性、健壯性、有效性、可伸縮性、可讀性、可重用性、簡潔性、可維護(hù)性、可擴(kuò)充行OOP典型特點:封裝性、繼承性、重載、屬性和修飾符、多態(tài)、重構(gòu)、抽象類接口、集合、泛型、委托與事件實現(xiàn)一個最簡單的實例計算立體型幾何體體積要點:分析其中的耦合性、程序的復(fù)用性“臟代碼”分析單一職責(zé)原則(SRP原則)就一個類而言,應(yīng)該只有一個引起它變化的原因;失敗的案例:界面處理類+數(shù)據(jù)庫操作+文件讀寫+業(yè)務(wù)流程控制類比:多功能手機(jī)、集成主板的電腦—壞一處就全壞經(jīng)驗:類的設(shè)計傾向于越小越好解釋:如果一個類承擔(dān)的職責(zé)過多,就等于把這些職責(zé)耦合在一起。一個職責(zé)的變化可能會引起消弱或抑制這個類完成其他職責(zé)的功能。這種耦合會導(dǎo)致脆弱的設(shè)計。當(dāng)變化發(fā)生時,設(shè)計會遭到意想不到的破壞。開-閉原則(核心原則)軟件實體(類、模塊、方法)應(yīng)該可以擴(kuò)展,但不可以修改;換個說法:類對擴(kuò)展是開放的,對修改是封閉的;用extends和implements等開放,用private封閉實際使用:1.隨時準(zhǔn)備修改:改變是合理的;2.原來的代碼一般不要改動,合理的方法是基于原先的代碼產(chǎn)生新的類3.設(shè)計之初就準(zhǔn)備好應(yīng)對變化,用抽象來隔離變化,減少耦合。開-閉原則的運用:寫一個相對固定的內(nèi)核;不斷產(chǎn)生新的類,當(dāng)修改發(fā)生時;新的類給予接口或抽象類創(chuàng)建;理解:面向接口編程依賴倒轉(zhuǎn)原則抽象不應(yīng)該依賴于細(xì)節(jié),細(xì)節(jié)應(yīng)該依賴于抽象;----針對接口編程,不要對實現(xiàn)編程解釋:1.高層類不應(yīng)該依賴低層類;兩者都應(yīng)依賴于抽象;2.抽象不應(yīng)該依賴細(xì)節(jié);細(xì)節(jié)應(yīng)該依賴抽象反轉(zhuǎn)實例:電話指揮修電腦,誰依賴誰?抽象與實現(xiàn):電腦主板-總線插槽-PIC卡的實例—抽象不依賴細(xì)節(jié),細(xì)節(jié)依賴抽象。依賴止于接口--用接口消除強(qiáng)耦合AB依賴AB依賴I依賴用接口消除強(qiáng)耦合OO的基本原則89、面向?qū)ο蟮幕驹O(shè)計原則

1)LSP(TheLiskovSubstitutionPrinciple):Liskov替換原則

子類不能添加任何父類沒有的附加約束。子類對象必須可以替換基類對象。

在可能的情況下,由抽象類(接口)繼承。

抽象類與具體類

只要有可能,不要從具體類繼承;

行為集中的方向是向上的(抽象類);

數(shù)據(jù)集中的方向是向下的(具體類)。

2)OCP(TheOpen-ClosePrinciple):開放-封閉原則

對于擴(kuò)展是開放的(Openforextension)

對于更改是封閉的(Closedformodification)

關(guān)鍵在于抽象

抽象預(yù)見了可能的所有擴(kuò)展(閉)

由抽象可以隨時導(dǎo)出新的類(開)

OCP是OOD中很多說法的核心。

LSP是OCP成為可能的主要原則之一。

3)SRP單一職責(zé)原則(TheSingleResponsibilityPrinciple)

一個類,應(yīng)該僅有一個引起它變化的原因。

體現(xiàn)了內(nèi)聚性(Cohesion):一個模塊的組成元素之間的功能相關(guān)性。

違反SRP原則會帶來物理依賴的缺點。

使得每個類僅有一個職責(zé)。

4)ISP接口隔離原則(TheInterfaceSegregationPrinciple)

客戶應(yīng)該僅知道所需要要的接口。

一個類實現(xiàn)多個接口,避免“肥接口(fatinterface)”

使用委托分離接口,Adapter模式;使用多重繼承分離接口。

本質(zhì):

使用多個專門的接口比使用單一的接口好。

一個類對另一個類的依賴性應(yīng)當(dāng)是建立在最小的接口上的。

避免接口污染(InterfacePollution)

5)DIP依賴倒置原則(TheDependencyInversionPrinciple)

高層模塊不依賴于低層模塊,二者都依賴于抽象。

抽象不應(yīng)該依賴于細(xì)節(jié),細(xì)節(jié)應(yīng)該依賴于抽象。

針對接口編程,而不是針對實現(xiàn)編程。

Booch:所有結(jié)構(gòu)良好面向?qū)ο蠹軜?gòu)都具有清晰地層次定義,每個層次通過一個定義良好的、受控的接口向外提供了一組類聚的服務(wù)。

6)啟發(fā)式原則

依賴于抽象——依賴關(guān)系都應(yīng)終止于抽象類或者接口。

任何變量都不應(yīng)該擁有指向具體類的指針或者引用。

任何類都不應(yīng)該從具體類派生。

任何方法都不應(yīng)該改寫其任何基類中已經(jīng)實現(xiàn)的方法。

UML圖類圖案例分析好友管理系統(tǒng)中的類圖分析好友管理系統(tǒng)中消息傳送過程分析--登錄過程分析--查詢過程分析--增加過程過程時序圖例子時序圖例子2時序圖例子3設(shè)計時序圖一般方法盡力保持消息的順序從左到右排列將分類器分

溫馨提示

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

最新文檔

評論

0/150

提交評論