面向?qū)ο蠓椒▽W(xué)引論課件_第1頁
面向?qū)ο蠓椒▽W(xué)引論課件_第2頁
面向?qū)ο蠓椒▽W(xué)引論課件_第3頁
面向?qū)ο蠓椒▽W(xué)引論課件_第4頁
面向?qū)ο蠓椒▽W(xué)引論課件_第5頁
已閱讀5頁,還剩129頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

第9章面向?qū)ο蠓椒▽W(xué)引論9.1面向?qū)ο蠓椒▽W(xué)概述9.2面向?qū)ο蟮母拍?.3面向?qū)ο蠼?.4對象模型9.5動態(tài)模型9.6功能模型9.73種模型之間的關(guān)系1第9章面向?qū)ο蠓椒▽W(xué)引論9.1面向?qū)ο蠓椒▽W(xué)概述11面向?qū)ο蟮母拍钇鹪从?0世紀(jì)60年代中期的Simula67。80年代中期OOP模式進(jìn)入主流。80年代中后期,面向?qū)ο蠓治雠c設(shè)計的研究開始發(fā)展。進(jìn)入90年代,面向?qū)ο筌浖こ坛闪嗽S多軟件產(chǎn)品的開發(fā)模式。§1面向?qū)ο蠓椒▽W(xué)概述2面向?qū)ο蟮母拍钇鹪从?0世紀(jì)60年代中期的Simula672面向?qū)ο蠓椒▽W(xué)OOM(Object-OrientedMethodology)特點:盡可能模擬人類習(xí)慣的思維方式,即問題域與求解域在結(jié)構(gòu)上盡可能一致。與傳統(tǒng)方法相反,OOM把數(shù)據(jù)和處理結(jié)合構(gòu)成統(tǒng)一體——對象。這時程序不再是一系列工作在數(shù)據(jù)上的函數(shù)集合,而是相互協(xié)作又彼此獨立的對象的集合。3面向?qū)ο蠓椒▽W(xué)OOM(Object-OrientedMet3成都北京Post-officeMessageSendbymethod對象ObjectObject=屬性AttributeAttributes:location;employee;……

+操作MethodMethods:send;sell;……注意:對象內(nèi)部的屬性不允許外部用戶直接改動,只有當(dāng)它提供了相應(yīng)的服務(wù)操作時,用戶才能通過發(fā)送消息來提請它執(zhí)行。我想把郵局搬到我家門口,多加幾個郵遞員,24小時都開門……對不起,本郵局不提供此類服務(wù)唉,那就先送束花吧——

Post_office.Send(request,payment)例:4成都北京Post-officeMessageSendby4OOM的四要素:①對象(object):世界由對象組成。②類(class):具有相同屬性和操作的對象可劃分為類;單個對象可視為某一類的實例

(instance)。③繼承(inheritance):類可分層,下層子類與上層父類有相同特征,稱為繼承。OOM=Object+Class+Inheritance+Communicationwithmessages④消息(message):對象間只能通過發(fā)送消息進(jìn)行聯(lián)系,外界不能處理對象的內(nèi)部數(shù)據(jù),只能通過消息請求它進(jìn)行處理(如果它提供相應(yīng)消息的話)。5OOM的四要素:①對象(object):世界由對象組成。②5OOM:以object為核心,強調(diào)對現(xiàn)實概念的模擬而不強調(diào)算法?!懊嫦?qū)ο蠓椒▽W(xué)的基本原則,是按照人們習(xí)慣的思維方式建立問題域的模型,開發(fā)出盡可能直觀、自然地表現(xiàn)求解方法的軟件系統(tǒng)”。

Class:由特殊到一般的歸納

Inheritance:由一般到特殊的演繹OOM相比傳統(tǒng)方法的優(yōu)點:①傳統(tǒng)方法:面向過程設(shè)計,以計算為核心,數(shù)據(jù)與操作分離,不易理解。6OOM:以object為核心,強調(diào)對現(xiàn)實概念的模擬而不強調(diào)6OOM:以object模擬實體,需求變化不會引起結(jié)構(gòu)的整體變化,因為實體相對穩(wěn)定,故系統(tǒng)也相應(yīng)穩(wěn)定。②傳統(tǒng)方法:結(jié)構(gòu)依賴于功能,不穩(wěn)定。③傳統(tǒng)方法:通過建立標(biāo)準(zhǔn)函數(shù)庫來重用軟構(gòu)件。但標(biāo)準(zhǔn)函數(shù)缺少必要的“柔性”,難以適應(yīng)不同場合的不同需要。OOM:一個class所有的instances都可重用它的代碼;由inheritance派生出的新的class可重用其父類的代碼,并且可以修改、擴充而不影響其父類的使用。7OOM:以object模擬實體,需求變化不會引起結(jié)構(gòu)的整體變7穩(wěn)定性好:軟件功能需求的變化不牽動全局,只需局部修改;Class獨立性強:只要修改不涉及class的對外接口,則內(nèi)部修改完全不影響外部調(diào)用;Inheritance和多態(tài)性(polymorphism)使其很容易被修改和擴充;容易理解;④傳統(tǒng)方法:可維護性是最令人頭痛的問題。

OOM:從以下幾方面改善了可維護性——注:OOM并不是減少了開發(fā)時間,而是通過提高可重用性、可維護性,進(jìn)行擴充和修改的容易程度等,從長遠(yuǎn)角度改進(jìn)了軟件的質(zhì)量。OOM與Prototyping結(jié)合使用效果好。8穩(wěn)定性好:軟件功能需求的變化不牽動全局,只需局部修改;④傳8特點:①以數(shù)據(jù)為中心,不設(shè)與數(shù)據(jù)無關(guān)的操作;②Object主動處理而不被動地等待被處理,外部只能通過message請求操作;③具有封裝性:外部操作時,無須知道該object內(nèi)部的數(shù)據(jù)結(jié)構(gòu)及算法;④具有并行性:不同object各自獨立地處理自身數(shù)據(jù),彼此間僅通過傳遞message完成通信;⑤模塊獨立性好:內(nèi)聚強、耦合松§2面向?qū)ο蟮母拍?、對象9特點:§2面向?qū)ο蟮母拍?、對象993、消息:object_ID.method_ID(parameter(s));4、方法(操作):object能做的操作,亦稱為service,在

class中須定義相應(yīng)的代碼;5、屬性

:object的固有數(shù)據(jù);2、類:具有相同數(shù)據(jù)和相同操作的一組對象;

實例:某個class描述的具體對象;6、封裝:把內(nèi)部實現(xiàn)細(xì)節(jié)隱藏起來,使其他外部對象無法訪問,僅僅提供某些功能。使對象形成接口部分和實現(xiàn)部分103、消息:object_ID.method_ID(pa10Class中國人中國人Attributes中國人Methods張三(instance)

Class中國人張三的AttributesClass成都人

(子類)成都人Attributes成都人Methods

Class中國人李四(instance)中國人李四的Attributes成都人李四的Attributes

Class成都人例:7、繼承:子類自動共享父類的attributes和methods,而不必重復(fù)定義。特點:①若成都人的methods中有與中國人的同名,則李四執(zhí)行該method時以成都人為準(zhǔn),不執(zhí)行中國人中定義的同名method。②傳遞性:AB、BCAC

一個class繼承了上層全部classes的一切性質(zhì)。11Class中國人中國人Attributes中國人Met11注意:多重繼承在定義中應(yīng)避免二義性,即兩二個父類中定義重名,但各具不同性質(zhì)。例:FemaleChineseScholarCardDeckGraphicalObjectGraphicalDeckMethod:Draw:=takeacardfromadeckMethod:Draw:=displayagraphicalobjectMethod:Draw:=?例:④修改與擴充可以很容易地通過派生子類來完成。③一個子類只有一個父類稱為單繼承,一個子類可有多個父類稱為多重繼承。12注意:多重繼承在定義中應(yīng)避免二義性,即兩二個父類中定義重名,128、多態(tài)性與動態(tài)聯(lián)編多態(tài)性是指子類對象可以像父類對象那樣使用,同樣的消息既可以發(fā)送給父類對象也可以發(fā)送給子類對象。不同層次的classes可共享一個method名,但按各自的方式來實現(xiàn)這種method。9、重載在同一作用域內(nèi)的若干個參數(shù)特征不同的函數(shù)可以使用相同的函數(shù)名字。在C++語言中函數(shù)重載通過靜態(tài)聯(lián)編(也叫先前聯(lián)編)實現(xiàn)。如虛函數(shù)機制能在一個類等級中使用相同函數(shù)的多個不同版本,在運行時刻才根據(jù)接收消息的對象所屬于的類,決定到底執(zhí)行哪個特定的版本,稱為動態(tài)聯(lián)編,也叫滯后聯(lián)編。138、多態(tài)性與動態(tài)聯(lián)編9、重載如虛函數(shù)機制能在一個類等級中使用13模型:為了理解事物而對事物作出的一種抽象,是對事物的一種無歧義的書面描述。

3種面向?qū)ο蟮哪P停?①

描述系統(tǒng)數(shù)據(jù)結(jié)構(gòu)的對象模型。 ②

描述系統(tǒng)控制結(jié)構(gòu)的動態(tài)模型。 ③

描述系統(tǒng)功能的功能模型。一個典型的軟件系統(tǒng)組合了上述3方面內(nèi)容:它使用數(shù)據(jù)結(jié)構(gòu)(對象模型),執(zhí)行操作(動態(tài)模型),并且完成數(shù)據(jù)值的變化(功能模型)。§3面向?qū)ο蠼?4模型:為了理解事物而對事物作出的一種抽象,是對事物的一種無歧14幾種面向?qū)ο箝_發(fā)方法:Booch方法Booch是面向?qū)ο蠓椒ㄗ钤绲奶岢稣咧唬岢隽嗣嫦驅(qū)ο筌浖こ痰母拍睢ooch認(rèn)為軟件開發(fā)是一個螺旋上升的過程。Coad-Yourdon方法著名的OOA/OOD方法,也是最早的面向?qū)ο蟮姆治雠c設(shè)計方法之一。簡單、易學(xué)。Rumbaugh方法(簡稱OMT-ObjectModelingTechnology)該方法強調(diào)了三種模型,并將軟件開發(fā)過程劃分為系統(tǒng)分析、系統(tǒng)設(shè)計、對象設(shè)計等幾個階段。Jacobson方法(簡稱OOSE)最大特點是強調(diào)使用用例(Use-Case),每一個用例就是一個使用系統(tǒng)的方式,用例的執(zhí)行將引發(fā)執(zhí)行一系列與行為相關(guān)的事務(wù)。15幾種面向?qū)ο箝_發(fā)方法:Booch方法1515統(tǒng)一建模語言UML由Rumbaugh、Booch、Jacobson提出的統(tǒng)一建模語言(UnifiedModeingLanguage)

,簡稱UML。產(chǎn)生于90年代中期。它不僅統(tǒng)一了Booch、OMT和OOSE方法中的概念和表示法,而且對其作了進(jìn)一步擴展,最終成為在面向?qū)ο蠹夹g(shù)領(lǐng)域占主導(dǎo)地位的、并被大眾所接受的標(biāo)準(zhǔn)建模語言。UML不是一個開發(fā)過程,也不是一個方法,但允許任何一種開發(fā)過程和面向?qū)ο蠓椒ㄊ褂盟?6統(tǒng)一建模語言UML由Rumbaugh、Booch、Ja16類圖用來描述系統(tǒng)中的類及類和類之間的靜態(tài)關(guān)系。類的表示:例如:可訪問性通常有3種:公有的(public)私有的(private)

保護的(protected),分別用加號(+)、減號(-)和井號(#)表示。類名類的簡單表示類的完整表示對象模型表現(xiàn)了客觀世界實體對象的相互關(guān)系。通常使用UML提供的類圖來建立對象模型?!?對象模型類圖的基本符號17類圖用來描述系統(tǒng)中的類及類和類之間的靜態(tài)關(guān)系。類的表示:例如17

類圖由類及類與類之間的關(guān)系組成。定義了類之后就可以定義類與類之間的各種關(guān)系了。類與類之間通常有關(guān)聯(lián)、泛化(繼承)、依賴和細(xì)化等4種關(guān)系。表示關(guān)系的符號18類圖由類及類與類之間的關(guān)系組成。定義了類之后18類1類2角色角色關(guān)聯(lián)名角色表示該類在這個關(guān)聯(lián)中的作用。如果沒有顯式標(biāo)出角色名,則意味著用類名作為角色名。重數(shù):該類有多少個對象與對方的一個對象連接。關(guān)聯(lián)表示兩個類的對象之間存在某種語義上的聯(lián)系。重數(shù)1、關(guān)聯(lián)19類1類2角色角色關(guān)聯(lián)名角色表示該類在這個關(guān)聯(lián)中的作用。如果沒19在表示關(guān)聯(lián)的直線兩端可以寫上重數(shù)(multiplicity),它表示該類有多少個對象與對方的一個對象連接。重數(shù)的表示方法通常有:0…1 表示0到1個對象0…*或* 表示0到多個對象1+或1…* 表示1到多個對象1…15 表示1到15個對象3 表示3個對象如果圖中未明確標(biāo)出關(guān)聯(lián)的重數(shù),則默認(rèn)重數(shù)是1。20在表示關(guān)聯(lián)的直線兩端可以寫上重數(shù)(multiplicity)20公司董事會默認(rèn)關(guān)聯(lián)名是has(有),省略重數(shù)默認(rèn)1。人員董事會成員0,3..8*董事會每一個董事會沒有或者有3~8個董事會成員(有角色名,可以省略關(guān)聯(lián)名)(1)普通關(guān)聯(lián)——最常見的關(guān)聯(lián)關(guān)系。例如:21公司董事會默認(rèn)關(guān)聯(lián)名是has(有),省略重數(shù)默認(rèn)1。人員董事21(2)遞歸關(guān)聯(lián)即一個類與它本身有關(guān)聯(lián)關(guān)系。例如:22(2)遞歸關(guān)聯(lián)例如:2222(3)限定關(guān)聯(lián)也叫受限關(guān)聯(lián),兩個類及一個限定詞組成,限定詞是一種特定的屬性,用來有效地減少關(guān)聯(lián)的重數(shù)。在類圖中把限定詞放在關(guān)聯(lián)關(guān)系末端的一個小方框內(nèi)。限定關(guān)聯(lián)通常用在一對多或多對多的關(guān)聯(lián)關(guān)系中,可以把模型中的重數(shù)從一對多變成一對一,或從多對多簡化成多對一。23(3)限定關(guān)聯(lián)限定關(guān)聯(lián)通常用在一對多或多對多的關(guān)聯(lián)關(guān)系中,23例如,某操作系統(tǒng)中一個目錄下有許多文件,一個文件僅屬于一個目錄,在一個目錄內(nèi)文件名確定了惟一一個文件。圖9.8利用限定詞“文件名”表示了目錄與文件之間的關(guān)系,可見,利用限定詞把一對多關(guān)系簡化成了一對一關(guān)系。圖9.8一個受限的關(guān)聯(lián)24例如,某操作系統(tǒng)中一個目錄下有許多文件,一個文件僅屬于一個目24限定提高了語義精確性,增強了查詢能力。在圖9.8中,限定的語法表明,文件名在其目錄內(nèi)是惟一的。因此,查找一個文件的方法就是,首先定下目錄,然后在該目錄內(nèi)查找指定的文件名。由于目錄加文件名可惟一地確定一個文件,因此,限定詞“文件名”應(yīng)該放在靠近目錄的那一端。25限定提高了語義精確性,增強了查詢能力。在圖9.8中,限定的語25在一些情況下關(guān)聯(lián)可能需要記錄一些信息,但這些信息不能放在任何一個類中,可引入一個關(guān)聯(lián)類記錄這些信息。關(guān)聯(lián)類通過一條虛線與關(guān)聯(lián)連接。學(xué)生*選修*課程一個多對多關(guān)聯(lián)?!俺煽儭睂傩圆荒芊旁谌魏我环綄W(xué)生**課程選修成績創(chuàng)建一個關(guān)聯(lián)類來保存成績,關(guān)聯(lián)類與一般的類一樣,也有屬性、操作和關(guān)聯(lián)。學(xué)生*選修*成績課程與帶有關(guān)聯(lián)類的多對多關(guān)聯(lián)等價的兩個一對多關(guān)聯(lián)的圖(4)關(guān)聯(lián)類26在一些情況下關(guān)聯(lián)可能需要記錄一些信息,但這些信息不能放在任何26整體類部分類整體類部分類共享聚集組合聚集2、聚集:組合是一種強類型的聚集,整體類和部分類共存亡,如果整體類被撤銷,部分類也不存在。表示“整體-部分”的特殊關(guān)聯(lián)例如:27整體類部分類整體類部分類共享聚集組合聚集2、聚集:組合是一種27(1)共享聚集如果在聚集關(guān)系中處于部分方的對象可同時參與多個處于整體方對象的構(gòu)成,則該聚集稱為共享聚集。例如,一個課題組包含許多成員,每個成員又可以是另一個課題組的成員,則課題組和成員之間是共享聚集關(guān)系,。(2)組合聚集如果部分類完全隸屬于整體類,部分與整體共存,整體不存在了部分也會隨之消失(或失去存在價值了),則該聚集稱為組合聚集(簡稱為組成)。例如,在屏幕上打開一個窗口,它就由文本框、列表框、按鈕和菜單組成,一旦關(guān)閉了窗口,各個組成部分也同時消失,窗口和它的組成部分之間存在著組合聚集關(guān)系。28(1)共享聚集28283.泛化UML中的泛化關(guān)系就是通常所說的繼承關(guān)系,它是通用元素和具體元素之間的一種分類關(guān)系。具體元素完全擁有通用元素的信息,并且還可以附加一些其他信息。在UML中,用一端為空心三角形的連線表示泛化關(guān)系,三角形的頂角緊挨著通用元素。注意,泛化針對類型而不針對實例,一個類可以繼承另一個類,但一個對象不能繼承另一個對象。實際上,泛化關(guān)系指出在類與類之間存在“一般-特殊”關(guān)系。泛化可進(jìn)一步劃分成普通泛化和受限泛化。293.泛化2929一般類特殊類人員教師學(xué)生由一個超類和幾個直接子類構(gòu)成的結(jié)構(gòu)通常稱為泛化。表示一般-特殊關(guān)系或繼承關(guān)系。例如:(1)普通泛化30一般類特殊類人員教師學(xué)生由一個超類和幾個直接子類構(gòu)成的結(jié)構(gòu)通30需要特別說明的是,沒有具體對象的類稱為抽象類。抽象類通常作為父類,用于描述其他類(子類)的公共屬性和行為。圖示抽象類時,在類名下方附加一個標(biāo)記值{abstract},如圖9.12所示。圖下方的兩個折角矩形是模型元素“筆記”的符號,其中的文字是注釋,分別說明兩個子類的操作drive的功能。抽象類通常都具有抽象操作。抽象操作僅用來指定該類的所有子類應(yīng)具有哪些行為。抽象操作的圖示方法與抽象類相似,在操作標(biāo)記后面跟隨一個性質(zhì)串{abstract}。31需要特別說明的是,沒有具體對象的類稱為抽象類。抽象類通常作為31圖9.12抽象類示例323232與抽象類相反的類是具體類,具體類有自己的對象,并且該類的操作都有具體的實現(xiàn)方法。圖9.13給出一個比較復(fù)雜的類圖示例,這個例子綜合應(yīng)用了前面講過的許多概念和圖示符號。333333圖9.13復(fù)雜類圖示例343434(2)受限泛化可以給泛化關(guān)系附加約束條件,以進(jìn)一步說明該泛化關(guān)系的使用方法或擴充方法,這樣的泛化關(guān)系稱為受限泛化。預(yù)定義的約束有4種:多重、不相交、完全和不完全。這些約束都是語義約束。多重繼承指的是,一個子類可以同時多次繼承同一個上層基類,例如圖9.14中的水陸兩用類繼承了兩次交通工具類。與多重繼承相反的是不相交繼承,即一個子類不能多次繼承同一個基類(這樣的基類相當(dāng)于C++語言中的虛基類)。如果圖中沒有指定{多重}約束,則是不相交繼承,一般的繼承都是不相交繼承。35(2)受限泛化3535圖9.14多重繼承示例363636完全繼承指的是父類的所有子類都已在類圖中窮舉出來了,圖示符號是指定{完全}約束。不完全繼承與完全繼承恰好相反,父類的子類并沒有都窮舉出來,隨著對問題理解的深入,可不斷補充和維護,這為日后系統(tǒng)的擴充和維護帶來很大方便。不完全繼承是一般情況下默認(rèn)的繼承關(guān)系。37完全繼承指的是父類的所有子類都已在類圖中窮舉出來了,圖示符號374、依賴和細(xì)化(1)依賴關(guān)系描述兩個模型元素(類、用例等)之間的語義連接關(guān)系:其中一個模型元素是獨立的,另一個模型元素不是獨立的,它依賴于獨立的模型元素。獨立類不獨立版類標(biāo)簽:說明依賴的種類例如:友元關(guān)系使得類B的操作可以使用A類中私有的或保護的成員。384、依賴和細(xì)化獨立類不獨立版類標(biāo)簽:說明依賴的種類例如:友元38(2)細(xì)化關(guān)系當(dāng)對同一個事物在不同抽象層次上描述時,這些描述之間具有細(xì)化關(guān)系。假設(shè)兩個模型元素A和B描述同一個事物,它們的區(qū)別是抽象層次不同,如果B是在A的基礎(chǔ)上的更詳細(xì)的描述,則稱B細(xì)化了A,或稱A細(xì)化成了B。細(xì)化用來協(xié)調(diào)不同階段模型之間的關(guān)系,表示各個開發(fā)階段不同抽象層次的模型之間的相關(guān)性,常常用于跟蹤模型的演變BA39(2)細(xì)化關(guān)系BA3939ClassNameAttributesMethodsClassClassNameAttributesMethodsClass-&-Object表示屬于該類的對象也可對類和對象用有區(qū)別的畫法:40ClassNameAttributesMethodsCla40動態(tài)模型表示瞬時的、行為化的系統(tǒng)的“控制”性質(zhì),它規(guī)定了對象模型中的對象的合法變化序列。一旦建立起對象模型之后,就需要考察對象的動態(tài)行為。所有對象都具有自己的生命周期(或稱為運行周期)。對一個對象來說,生命周期由許多階段組成,在每個特定階段中,都有適合該對象的一組運行規(guī)律和行為規(guī)則,用以規(guī)范該對象的行為。生命周期中的階段也就是對象的狀態(tài)。動態(tài)模型:表示系統(tǒng)瞬時的控制性質(zhì)§5動態(tài)模型41動態(tài)模型表示瞬時的、行為化的系統(tǒng)的“控制”性質(zhì),它規(guī)定了對象41狀態(tài)1do/活動1狀態(tài)2do/活動2事件[條件]/動作其中:狀態(tài)內(nèi)部的“活動”不引起狀態(tài)轉(zhuǎn)移;箭頭上的“動作”指狀態(tài)轉(zhuǎn)移時要執(zhí)行的動作。注:當(dāng)描述循環(huán)運行過程時,通常不關(guān)心是怎樣啟動的。三要素:①事件:引發(fā)object狀態(tài)改變的控制信息(瞬時)。②狀態(tài):即

object的

attributes所處的情形(可持續(xù))。③活動:Object要達(dá)到某種status所做的操作(耗時)。狀態(tài)圖42狀態(tài)1do/活動1狀態(tài)2do/活動2事件[條件]/動作其42通常,用UML提供的狀態(tài)圖來描繪對象的狀態(tài)、觸發(fā)狀態(tài)轉(zhuǎn)換的事件以及對象的行為(對事件的響應(yīng))。每個類的動態(tài)行為用一張狀態(tài)圖來描繪,各個類的狀態(tài)圖通過共享事件合并起來,從而構(gòu)成系統(tǒng)的動態(tài)模型。也就是說,動態(tài)模型是基于事件共享而互相關(guān)聯(lián)的一組狀態(tài)圖的集合。43通常,用UML提供的狀態(tài)圖來描繪對象的狀態(tài)、觸發(fā)狀態(tài)轉(zhuǎn)換的事43閑置撥號通話斷線撥號音do:響撥號音超時do:響蜂鳴音存儲的信息do:播放信息接通中do:試接通振鈴do:振鈴忙音do:響忙音拿起聽筒數(shù)字?jǐn)?shù)字有效號碼已接通受話人回話受話人掛斷電話掛斷電話超時掛斷電話超時無效號碼信息播完占線例:電話的狀態(tài)圖44閑置撥號通話斷線撥號音超時存儲的信息接通中振鈴忙44UML提供的用例圖也是建立功能模型的強有力工具。在UML中把用用例圖建立起來的系統(tǒng)模型稱為用例模型,一個用例模型由若干幅用例圖組成?!?功能模型功能模型:表明系統(tǒng)應(yīng)該做什么通常的表示方法:數(shù)據(jù)流圖(DFD)用例圖僅僅從參與者使用系統(tǒng)的角度描述系統(tǒng),不反映內(nèi)部的處理方式。因此用例圖定義的是系統(tǒng)的功能需求。其主要目的是以一種可視化的方式理解系統(tǒng)的功能需求。

一幅用例圖包含的模型元素有系統(tǒng)、行為者、用例及用例之間的關(guān)系。45UML提供的用例圖也是建立功能模型的強有力工具。在UML中把45用例建模的主要步驟:首先定義一個系統(tǒng);并在該系統(tǒng)中確定執(zhí)行者;確定用例,描述每一個用例;確定關(guān)系(包括用例與執(zhí)行者之間的關(guān)系,執(zhí)行者之間的關(guān)系,用例之間的關(guān)系);最后確認(rèn)所建的模型。46用例建模的主要步驟:46461.系統(tǒng)系統(tǒng)被看作是一個提供用例的黑盒子,內(nèi)部如何工作、用例如何實現(xiàn),這些對于建立用例模型來說都是不重要的。代表系統(tǒng)的方框的邊線表示系統(tǒng)的邊界,用于劃定系統(tǒng)的功能范圍,定義了系統(tǒng)所具有的功能。描述該系統(tǒng)功能的用例置于方框內(nèi),代表外部實體的行為者置于方框外。9.6.1用例圖471.系統(tǒng)9.6.1用例圖4747例如:48例如:4848簽定一份保險單客戶保險銷售人員銷售統(tǒng)計客戶統(tǒng)計某保險業(yè)務(wù)的用例圖又如:49簽定一份客戶保險銷銷售統(tǒng)計客戶統(tǒng)計某保險業(yè)務(wù)的用例圖又如:4492.用例一個用例是可以被行為者感受到的、系統(tǒng)的一個完整的功能。在UML中把用例定義成系統(tǒng)完成的一系列動作,動作的結(jié)果能被特定的行為者察覺到。這些動作除了完成系統(tǒng)內(nèi)部的計算與工作外,還包括與一些行為者的通信。用例通過關(guān)聯(lián)與行為者連接,關(guān)聯(lián)指出一個用例與哪些行為者交互,這種交互是雙向的。用例具有下述特征:(1)用例代表某些用戶可見的功能,實現(xiàn)一個具體的用戶目標(biāo);502.用例5050(2)用例總是被行為者啟動的,并向行為者提供可識別的值;(3)用例必須是完整的。注意,用例是一個類,它代表一類功能而不是使用該功能的某個具體實例。用例的實例是系統(tǒng)的一種實際使用方法,通常把用例的實例稱為腳本。腳本是系統(tǒng)的一次具體執(zhí)行過程,例如,在自動售貨機系統(tǒng)中,張三投入硬幣購買礦泉水,系統(tǒng)收到錢后把礦泉水送出來,上述過程就是一個腳本;李四投幣買可樂,但是可樂已賣完了,于是系統(tǒng)給出提示信息并把錢退還給李四,這個過程是另一個腳本。51(2)用例總是被行為者啟動的,并向行為者提供可識別的值;5513.行為者行為者是指與系統(tǒng)交互的人或其他系統(tǒng),它代表外部實體。使用用例并且與系統(tǒng)交互的任何人或物都是行為者。行為者代表一種角色,而不是某個具體的人或物。事實上,一個具體的人可以充當(dāng)多種不同角色。523.行為者5252在用例圖中用直線連接行為者和用例,表示兩者之間交換信息,稱為通信聯(lián)系。行為者觸發(fā)(激活)用例,并與用例交換信息。單個行為者可與多個用例聯(lián)系;反之,一個用例也可與多個行為者聯(lián)系。對于同一個用例而言,不同行為者起的作用也不同??梢园研袨檎叻殖芍餍袨檎吆透毙袨檎?,還可分成主動行為者和被動行為者。實踐表明,行為者對確定用例是非常有用的。面對一個大型、復(fù)雜的系統(tǒng),要列出用例清單往往很困難,可以先列出行為者清單,再針對每個行為者列出它的用例。這樣做可以比較容易地建立起用例模型。53在用例圖中用直線連接行為者和用例,表示兩者之間交換信息,稱為534.用例之間的關(guān)系UML用例之間主要有擴展和使用兩種關(guān)系,它們是泛化關(guān)系的兩種不同形式。(1)擴展關(guān)系向一個用例中添加一些動作后構(gòu)成了另一個用例,這兩個用例之間的關(guān)系就是擴展關(guān)系,后者繼承前者的一些行為,通常把后者稱為擴展用例。例如,在自動售貨機系統(tǒng)中,“售貨”是一個基本的用例,如果顧客購買罐裝飲料,售貨功能完成得很順利,但是,如果顧客要購買用紙杯裝的散裝飲料,則不能執(zhí)行該用例提供的常規(guī)動作,而要做些改動。544.用例之間的關(guān)系5454我們可以修改售貨用例,使之既能提供售罐裝飲料的常規(guī)動作又能提供售散裝飲料的非常規(guī)動作,但是,這將把該用例與一些特殊的判斷和邏輯混雜在一起,使正常的流程晦澀難懂。圖9.18中把常規(guī)動作放在“售貨”用例中,而把非常規(guī)動作放置于“售散裝飲料”用例中,這兩個用例之間的關(guān)系就是擴展關(guān)系。在用例圖中,用例之間的擴展關(guān)系圖示為帶版類《擴展》的泛化關(guān)系。55我們可以修改售貨用例,使之既能提供售罐裝飲料的常規(guī)動作又能提55圖9.18含擴展和使用關(guān)系的用例圖565656(2)使用關(guān)系當(dāng)一個用例使用另一個用例時,這兩個用例之間就構(gòu)成了使用關(guān)系。一般說來,如果在若干個用例中有某些相同的動作,則可以把這些相同的動作提取出來單獨構(gòu)成一個用例(稱為抽象用例)。這樣,當(dāng)某個用例使用該抽象用例時,就好像這個用例包含了抽象用例中的所有動作。在用例圖中,用例之間的使用關(guān)系用帶版類《使用》的泛化關(guān)系表示,如圖9.18所示。57(2)使用關(guān)系5757請注意擴展與使用之間的異同:這兩種關(guān)系都意味著從幾個用例中抽取那些公共的行為并放入一個單獨的用例中,而這個用例被其他用例使用或擴展,但是,使用和擴展的目的是不同的。通常在描述一般行為的變化時采用擴展關(guān)系;在兩個或多個用例中出現(xiàn)重復(fù)描述又想避免這種重復(fù)時,可以采用使用關(guān)系。58請注意擴展與使用之間的異同:這兩種關(guān)系都意味著從幾個用例中58幾乎在任何情況下都需要使用用例,通過用例可以獲取用戶需求,規(guī)劃和控制項目。獲取用例是需求分析階段的主要工作之一,而且是首先要做的工作。大部分用例將在項目的需求分析階段產(chǎn)生,并且隨著開發(fā)工作的深入還會發(fā)現(xiàn)更多用例,這些新發(fā)現(xiàn)的用例都應(yīng)及時補充進(jìn)已有的用例集中。用例集中的每個用例都是對系統(tǒng)的一個潛在的需求。9.6.2用例建模59幾乎在任何情況下都需要使用用例,通過用例可以獲取用戶需求,規(guī)59一個用例模型由若干幅用例圖組成。創(chuàng)建用例模型的工作包括:定義系統(tǒng),尋找行為者和用例,描述用例,定義用例之間的關(guān)系,確認(rèn)模型。其中,尋找行為者和用例是關(guān)鍵。1.尋找行為者為獲取用例首先要找出系統(tǒng)的行為者,可以通過請系統(tǒng)的用戶回答一些問題的辦法來發(fā)現(xiàn)行為者。下述問題有助于發(fā)現(xiàn)行為者:誰將使用系統(tǒng)的主要功能(主行為者)?誰需要借助系統(tǒng)的支持來完成日常工作?誰來維護和管理系統(tǒng)(副行為者)?系統(tǒng)控制哪些硬件設(shè)備?60一個用例模型由若干幅用例圖組成。創(chuàng)建用例模型的工作包括:定60系統(tǒng)需要與哪些其他系統(tǒng)交互?哪些人或系統(tǒng)對本系統(tǒng)產(chǎn)生的結(jié)果(值)感興趣?2.尋找用例一旦找到了行為者,就可以通過請每個行為者回答下述問題來獲取用例:行為者需要系統(tǒng)提供哪些功能?行為者自身需要做什么?行為者是否需要讀取、創(chuàng)建、刪除、修改或存儲系統(tǒng)中的某類信息?系統(tǒng)中發(fā)生的事件需要通知行為者嗎?行為者需要通知系統(tǒng)某些事情嗎?從功能觀點看,這些事件能做什么?61系統(tǒng)需要與哪些其他系統(tǒng)交互?6161行為者的日常工作是否因為系統(tǒng)的新功能而被簡化或提高了效率?還有一些不是針對具體行為者而是針對整個系統(tǒng)的問題,也能幫助建模者發(fā)現(xiàn)用例,例如:系統(tǒng)需要哪些輸入輸出?輸入來自何處?輸出到哪里去?當(dāng)前使用的系統(tǒng)(可能是人工系統(tǒng))存在的主要問題是什么?注意,最后這兩個問題并不意味著沒有行為者也可以有用例,只是在獲取用例時還不知道行為者是誰。事實上,一個用例必須至少與一個行為者相關(guān)聯(lián)。62行為者的日常工作是否因為系統(tǒng)的新功能而被簡化或提高了效率?662可用的構(gòu)造型元素:

當(dāng)描述一般行為時有例外、任選或異常處理時,采用《extend》(或《擴展》)。當(dāng)在兩個或多個用例中出現(xiàn)重復(fù)描述(有共用行為)而又想避免重復(fù)時,采用《include》(或《使用》)

。63可用的構(gòu)造型元素:6363某金融貿(mào)易系統(tǒng)用例圖設(shè)置邊界風(fēng)險分析交易估價進(jìn)行交易超越邊界更新帳目評價交易人員交易經(jīng)理計帳系統(tǒng)銷售員《extend》《include》《include》又如:注:“設(shè)置邊界”用例是指對某個特定用戶規(guī)定最大貿(mào)易量64某金融貿(mào)易系統(tǒng)用例圖設(shè)置邊界風(fēng)險分析交易估價進(jìn)行交易超越邊界64這三種模型都涉及到數(shù)據(jù)、控制和操作等概念,只是每種模型描述的側(cè)重點不同。它們各自從不同的側(cè)面反映了系統(tǒng)的實質(zhì)性內(nèi)容,綜合起來則全面反映了對目標(biāo)系統(tǒng)的需求。對象模型是最基本、最核心、最重要的?!?三種模型之間的關(guān)系FM:做什么WhatDM:何時做WhenOM:操作的實體How4)三者關(guān)系65這三種模型都涉及到數(shù)據(jù)、控制和操作等概念,只是每種模65OMDMFMObjectDMActionProcessMethodDatastorageDataflowAttributeEvent對每個object(class)建立DM;Action對應(yīng)DFD中的process以及OM中的method;FM中的process對應(yīng)OM中的method;FM中的數(shù)據(jù)存儲及數(shù)據(jù)的源/終點對應(yīng)OM中的object;FM中的數(shù)據(jù)流對應(yīng)OM中的attribute,或是整個object;FM中的process產(chǎn)生DM中的event;OM描述了FM中的動作對象、數(shù)據(jù)存儲及數(shù)據(jù)流的結(jié)構(gòu)。建立順序:66OMDMFMObjectDMActionProcessMet66用面向?qū)ο笥^點建立系統(tǒng)的模型,能夠促進(jìn)和加深對系統(tǒng)的理解,有助于開發(fā)出更容易理解、更容易維護的軟件。通常,使用UML的類圖來建立對象模型,使用UML的狀態(tài)圖來建立動態(tài)模型,使用數(shù)據(jù)流圖或UML的用例圖來建立功能模型。在UML中把用用例圖建立起來的系統(tǒng)模型稱為用例模型。67用面向?qū)ο笥^點建立系統(tǒng)的模型,能夠促進(jìn)和加深對系統(tǒng)的理解,有67第9章面向?qū)ο蠓椒▽W(xué)引論9.1面向?qū)ο蠓椒▽W(xué)概述9.2面向?qū)ο蟮母拍?.3面向?qū)ο蠼?.4對象模型9.5動態(tài)模型9.6功能模型9.73種模型之間的關(guān)系68第9章面向?qū)ο蠓椒▽W(xué)引論9.1面向?qū)ο蠓椒▽W(xué)概述168面向?qū)ο蟮母拍钇鹪从?0世紀(jì)60年代中期的Simula67。80年代中期OOP模式進(jìn)入主流。80年代中后期,面向?qū)ο蠓治雠c設(shè)計的研究開始發(fā)展。進(jìn)入90年代,面向?qū)ο筌浖こ坛闪嗽S多軟件產(chǎn)品的開發(fā)模式?!?面向?qū)ο蠓椒▽W(xué)概述69面向?qū)ο蟮母拍钇鹪从?0世紀(jì)60年代中期的Simula6769面向?qū)ο蠓椒▽W(xué)OOM(Object-OrientedMethodology)特點:盡可能模擬人類習(xí)慣的思維方式,即問題域與求解域在結(jié)構(gòu)上盡可能一致。與傳統(tǒng)方法相反,OOM把數(shù)據(jù)和處理結(jié)合構(gòu)成統(tǒng)一體——對象。這時程序不再是一系列工作在數(shù)據(jù)上的函數(shù)集合,而是相互協(xié)作又彼此獨立的對象的集合。70面向?qū)ο蠓椒▽W(xué)OOM(Object-OrientedMet70成都北京Post-officeMessageSendbymethod對象ObjectObject=屬性AttributeAttributes:location;employee;……

+操作MethodMethods:send;sell;……注意:對象內(nèi)部的屬性不允許外部用戶直接改動,只有當(dāng)它提供了相應(yīng)的服務(wù)操作時,用戶才能通過發(fā)送消息來提請它執(zhí)行。我想把郵局搬到我家門口,多加幾個郵遞員,24小時都開門……對不起,本郵局不提供此類服務(wù)唉,那就先送束花吧——

Post_office.Send(request,payment)例:71成都北京Post-officeMessageSendby71OOM的四要素:①對象(object):世界由對象組成。②類(class):具有相同屬性和操作的對象可劃分為類;單個對象可視為某一類的實例

(instance)。③繼承(inheritance):類可分層,下層子類與上層父類有相同特征,稱為繼承。OOM=Object+Class+Inheritance+Communicationwithmessages④消息(message):對象間只能通過發(fā)送消息進(jìn)行聯(lián)系,外界不能處理對象的內(nèi)部數(shù)據(jù),只能通過消息請求它進(jìn)行處理(如果它提供相應(yīng)消息的話)。72OOM的四要素:①對象(object):世界由對象組成。②72OOM:以object為核心,強調(diào)對現(xiàn)實概念的模擬而不強調(diào)算法?!懊嫦?qū)ο蠓椒▽W(xué)的基本原則,是按照人們習(xí)慣的思維方式建立問題域的模型,開發(fā)出盡可能直觀、自然地表現(xiàn)求解方法的軟件系統(tǒng)”。

Class:由特殊到一般的歸納

Inheritance:由一般到特殊的演繹OOM相比傳統(tǒng)方法的優(yōu)點:①傳統(tǒng)方法:面向過程設(shè)計,以計算為核心,數(shù)據(jù)與操作分離,不易理解。73OOM:以object為核心,強調(diào)對現(xiàn)實概念的模擬而不強調(diào)73OOM:以object模擬實體,需求變化不會引起結(jié)構(gòu)的整體變化,因為實體相對穩(wěn)定,故系統(tǒng)也相應(yīng)穩(wěn)定。②傳統(tǒng)方法:結(jié)構(gòu)依賴于功能,不穩(wěn)定。③傳統(tǒng)方法:通過建立標(biāo)準(zhǔn)函數(shù)庫來重用軟構(gòu)件。但標(biāo)準(zhǔn)函數(shù)缺少必要的“柔性”,難以適應(yīng)不同場合的不同需要。OOM:一個class所有的instances都可重用它的代碼;由inheritance派生出的新的class可重用其父類的代碼,并且可以修改、擴充而不影響其父類的使用。74OOM:以object模擬實體,需求變化不會引起結(jié)構(gòu)的整體變74穩(wěn)定性好:軟件功能需求的變化不牽動全局,只需局部修改;Class獨立性強:只要修改不涉及class的對外接口,則內(nèi)部修改完全不影響外部調(diào)用;Inheritance和多態(tài)性(polymorphism)使其很容易被修改和擴充;容易理解;④傳統(tǒng)方法:可維護性是最令人頭痛的問題。

OOM:從以下幾方面改善了可維護性——注:OOM并不是減少了開發(fā)時間,而是通過提高可重用性、可維護性,進(jìn)行擴充和修改的容易程度等,從長遠(yuǎn)角度改進(jìn)了軟件的質(zhì)量。OOM與Prototyping結(jié)合使用效果好。75穩(wěn)定性好:軟件功能需求的變化不牽動全局,只需局部修改;④傳75特點:①以數(shù)據(jù)為中心,不設(shè)與數(shù)據(jù)無關(guān)的操作;②Object主動處理而不被動地等待被處理,外部只能通過message請求操作;③具有封裝性:外部操作時,無須知道該object內(nèi)部的數(shù)據(jù)結(jié)構(gòu)及算法;④具有并行性:不同object各自獨立地處理自身數(shù)據(jù),彼此間僅通過傳遞message完成通信;⑤模塊獨立性好:內(nèi)聚強、耦合松§2面向?qū)ο蟮母拍?、對象76特點:§2面向?qū)ο蟮母拍?、對象9763、消息:object_ID.method_ID(parameter(s));4、方法(操作):object能做的操作,亦稱為service,在

class中須定義相應(yīng)的代碼;5、屬性

:object的固有數(shù)據(jù);2、類:具有相同數(shù)據(jù)和相同操作的一組對象;

實例:某個class描述的具體對象;6、封裝:把內(nèi)部實現(xiàn)細(xì)節(jié)隱藏起來,使其他外部對象無法訪問,僅僅提供某些功能。使對象形成接口部分和實現(xiàn)部分773、消息:object_ID.method_ID(pa77Class中國人中國人Attributes中國人Methods張三(instance)

Class中國人張三的AttributesClass成都人

(子類)成都人Attributes成都人Methods

Class中國人李四(instance)中國人李四的Attributes成都人李四的Attributes

Class成都人例:7、繼承:子類自動共享父類的attributes和methods,而不必重復(fù)定義。特點:①若成都人的methods中有與中國人的同名,則李四執(zhí)行該method時以成都人為準(zhǔn),不執(zhí)行中國人中定義的同名method。②傳遞性:AB、BCAC

一個class繼承了上層全部classes的一切性質(zhì)。78Class中國人中國人Attributes中國人Met78注意:多重繼承在定義中應(yīng)避免二義性,即兩二個父類中定義重名,但各具不同性質(zhì)。例:FemaleChineseScholarCardDeckGraphicalObjectGraphicalDeckMethod:Draw:=takeacardfromadeckMethod:Draw:=displayagraphicalobjectMethod:Draw:=?例:④修改與擴充可以很容易地通過派生子類來完成。③一個子類只有一個父類稱為單繼承,一個子類可有多個父類稱為多重繼承。79注意:多重繼承在定義中應(yīng)避免二義性,即兩二個父類中定義重名,798、多態(tài)性與動態(tài)聯(lián)編多態(tài)性是指子類對象可以像父類對象那樣使用,同樣的消息既可以發(fā)送給父類對象也可以發(fā)送給子類對象。不同層次的classes可共享一個method名,但按各自的方式來實現(xiàn)這種method。9、重載在同一作用域內(nèi)的若干個參數(shù)特征不同的函數(shù)可以使用相同的函數(shù)名字。在C++語言中函數(shù)重載通過靜態(tài)聯(lián)編(也叫先前聯(lián)編)實現(xiàn)。如虛函數(shù)機制能在一個類等級中使用相同函數(shù)的多個不同版本,在運行時刻才根據(jù)接收消息的對象所屬于的類,決定到底執(zhí)行哪個特定的版本,稱為動態(tài)聯(lián)編,也叫滯后聯(lián)編。808、多態(tài)性與動態(tài)聯(lián)編9、重載如虛函數(shù)機制能在一個類等級中使用80模型:為了理解事物而對事物作出的一種抽象,是對事物的一種無歧義的書面描述。

3種面向?qū)ο蟮哪P停?①

描述系統(tǒng)數(shù)據(jù)結(jié)構(gòu)的對象模型。 ②

描述系統(tǒng)控制結(jié)構(gòu)的動態(tài)模型。 ③

描述系統(tǒng)功能的功能模型。一個典型的軟件系統(tǒng)組合了上述3方面內(nèi)容:它使用數(shù)據(jù)結(jié)構(gòu)(對象模型),執(zhí)行操作(動態(tài)模型),并且完成數(shù)據(jù)值的變化(功能模型)?!?面向?qū)ο蠼?1模型:為了理解事物而對事物作出的一種抽象,是對事物的一種無歧81幾種面向?qū)ο箝_發(fā)方法:Booch方法Booch是面向?qū)ο蠓椒ㄗ钤绲奶岢稣咧?,提出了面向?qū)ο筌浖こ痰母拍睢ooch認(rèn)為軟件開發(fā)是一個螺旋上升的過程。Coad-Yourdon方法著名的OOA/OOD方法,也是最早的面向?qū)ο蟮姆治雠c設(shè)計方法之一。簡單、易學(xué)。Rumbaugh方法(簡稱OMT-ObjectModelingTechnology)該方法強調(diào)了三種模型,并將軟件開發(fā)過程劃分為系統(tǒng)分析、系統(tǒng)設(shè)計、對象設(shè)計等幾個階段。Jacobson方法(簡稱OOSE)最大特點是強調(diào)使用用例(Use-Case),每一個用例就是一個使用系統(tǒng)的方式,用例的執(zhí)行將引發(fā)執(zhí)行一系列與行為相關(guān)的事務(wù)。82幾種面向?qū)ο箝_發(fā)方法:Booch方法1582統(tǒng)一建模語言UML由Rumbaugh、Booch、Jacobson提出的統(tǒng)一建模語言(UnifiedModeingLanguage)

,簡稱UML。產(chǎn)生于90年代中期。它不僅統(tǒng)一了Booch、OMT和OOSE方法中的概念和表示法,而且對其作了進(jìn)一步擴展,最終成為在面向?qū)ο蠹夹g(shù)領(lǐng)域占主導(dǎo)地位的、并被大眾所接受的標(biāo)準(zhǔn)建模語言。UML不是一個開發(fā)過程,也不是一個方法,但允許任何一種開發(fā)過程和面向?qū)ο蠓椒ㄊ褂盟?3統(tǒng)一建模語言UML由Rumbaugh、Booch、Ja83類圖用來描述系統(tǒng)中的類及類和類之間的靜態(tài)關(guān)系。類的表示:例如:可訪問性通常有3種:公有的(public)私有的(private)

保護的(protected),分別用加號(+)、減號(-)和井號(#)表示。類名類的簡單表示類的完整表示對象模型表現(xiàn)了客觀世界實體對象的相互關(guān)系。通常使用UML提供的類圖來建立對象模型?!?對象模型類圖的基本符號84類圖用來描述系統(tǒng)中的類及類和類之間的靜態(tài)關(guān)系。類的表示:例如84

類圖由類及類與類之間的關(guān)系組成。定義了類之后就可以定義類與類之間的各種關(guān)系了。類與類之間通常有關(guān)聯(lián)、泛化(繼承)、依賴和細(xì)化等4種關(guān)系。表示關(guān)系的符號85類圖由類及類與類之間的關(guān)系組成。定義了類之后85類1類2角色角色關(guān)聯(lián)名角色表示該類在這個關(guān)聯(lián)中的作用。如果沒有顯式標(biāo)出角色名,則意味著用類名作為角色名。重數(shù):該類有多少個對象與對方的一個對象連接。關(guān)聯(lián)表示兩個類的對象之間存在某種語義上的聯(lián)系。重數(shù)1、關(guān)聯(lián)86類1類2角色角色關(guān)聯(lián)名角色表示該類在這個關(guān)聯(lián)中的作用。如果沒86在表示關(guān)聯(lián)的直線兩端可以寫上重數(shù)(multiplicity),它表示該類有多少個對象與對方的一個對象連接。重數(shù)的表示方法通常有:0…1 表示0到1個對象0…*或* 表示0到多個對象1+或1…* 表示1到多個對象1…15 表示1到15個對象3 表示3個對象如果圖中未明確標(biāo)出關(guān)聯(lián)的重數(shù),則默認(rèn)重數(shù)是1。87在表示關(guān)聯(lián)的直線兩端可以寫上重數(shù)(multiplicity)87公司董事會默認(rèn)關(guān)聯(lián)名是has(有),省略重數(shù)默認(rèn)1。人員董事會成員0,3..8*董事會每一個董事會沒有或者有3~8個董事會成員(有角色名,可以省略關(guān)聯(lián)名)(1)普通關(guān)聯(lián)——最常見的關(guān)聯(lián)關(guān)系。例如:88公司董事會默認(rèn)關(guān)聯(lián)名是has(有),省略重數(shù)默認(rèn)1。人員董事88(2)遞歸關(guān)聯(lián)即一個類與它本身有關(guān)聯(lián)關(guān)系。例如:89(2)遞歸關(guān)聯(lián)例如:2289(3)限定關(guān)聯(lián)也叫受限關(guān)聯(lián),兩個類及一個限定詞組成,限定詞是一種特定的屬性,用來有效地減少關(guān)聯(lián)的重數(shù)。在類圖中把限定詞放在關(guān)聯(lián)關(guān)系末端的一個小方框內(nèi)。限定關(guān)聯(lián)通常用在一對多或多對多的關(guān)聯(lián)關(guān)系中,可以把模型中的重數(shù)從一對多變成一對一,或從多對多簡化成多對一。90(3)限定關(guān)聯(lián)限定關(guān)聯(lián)通常用在一對多或多對多的關(guān)聯(lián)關(guān)系中,90例如,某操作系統(tǒng)中一個目錄下有許多文件,一個文件僅屬于一個目錄,在一個目錄內(nèi)文件名確定了惟一一個文件。圖9.8利用限定詞“文件名”表示了目錄與文件之間的關(guān)系,可見,利用限定詞把一對多關(guān)系簡化成了一對一關(guān)系。圖9.8一個受限的關(guān)聯(lián)91例如,某操作系統(tǒng)中一個目錄下有許多文件,一個文件僅屬于一個目91限定提高了語義精確性,增強了查詢能力。在圖9.8中,限定的語法表明,文件名在其目錄內(nèi)是惟一的。因此,查找一個文件的方法就是,首先定下目錄,然后在該目錄內(nèi)查找指定的文件名。由于目錄加文件名可惟一地確定一個文件,因此,限定詞“文件名”應(yīng)該放在靠近目錄的那一端。92限定提高了語義精確性,增強了查詢能力。在圖9.8中,限定的語92在一些情況下關(guān)聯(lián)可能需要記錄一些信息,但這些信息不能放在任何一個類中,可引入一個關(guān)聯(lián)類記錄這些信息。關(guān)聯(lián)類通過一條虛線與關(guān)聯(lián)連接。學(xué)生*選修*課程一個多對多關(guān)聯(lián)?!俺煽儭睂傩圆荒芊旁谌魏我环綄W(xué)生**課程選修成績創(chuàng)建一個關(guān)聯(lián)類來保存成績,關(guān)聯(lián)類與一般的類一樣,也有屬性、操作和關(guān)聯(lián)。學(xué)生*選修*成績課程與帶有關(guān)聯(lián)類的多對多關(guān)聯(lián)等價的兩個一對多關(guān)聯(lián)的圖(4)關(guān)聯(lián)類93在一些情況下關(guān)聯(lián)可能需要記錄一些信息,但這些信息不能放在任何93整體類部分類整體類部分類共享聚集組合聚集2、聚集:組合是一種強類型的聚集,整體類和部分類共存亡,如果整體類被撤銷,部分類也不存在。表示“整體-部分”的特殊關(guān)聯(lián)例如:94整體類部分類整體類部分類共享聚集組合聚集2、聚集:組合是一種94(1)共享聚集如果在聚集關(guān)系中處于部分方的對象可同時參與多個處于整體方對象的構(gòu)成,則該聚集稱為共享聚集。例如,一個課題組包含許多成員,每個成員又可以是另一個課題組的成員,則課題組和成員之間是共享聚集關(guān)系,。(2)組合聚集如果部分類完全隸屬于整體類,部分與整體共存,整體不存在了部分也會隨之消失(或失去存在價值了),則該聚集稱為組合聚集(簡稱為組成)。例如,在屏幕上打開一個窗口,它就由文本框、列表框、按鈕和菜單組成,一旦關(guān)閉了窗口,各個組成部分也同時消失,窗口和它的組成部分之間存在著組合聚集關(guān)系。95(1)共享聚集28953.泛化UML中的泛化關(guān)系就是通常所說的繼承關(guān)系,它是通用元素和具體元素之間的一種分類關(guān)系。具體元素完全擁有通用元素的信息,并且還可以附加一些其他信息。在UML中,用一端為空心三角形的連線表示泛化關(guān)系,三角形的頂角緊挨著通用元素。注意,泛化針對類型而不針對實例,一個類可以繼承另一個類,但一個對象不能繼承另一個對象。實際上,泛化關(guān)系指出在類與類之間存在“一般-特殊”關(guān)系。泛化可進(jìn)一步劃分成普通泛化和受限泛化。963.泛化2996一般類特殊類人員教師學(xué)生由一個超類和幾個直接子類構(gòu)成的結(jié)構(gòu)通常稱為泛化。表示一般-特殊關(guān)系或繼承關(guān)系。例如:(1)普通泛化97一般類特殊類人員教師學(xué)生由一個超類和幾個直接子類構(gòu)成的結(jié)構(gòu)通97需要特別說明的是,沒有具體對象的類稱為抽象類。抽象類通常作為父類,用于描述其他類(子類)的公共屬性和行為。圖示抽象類時,在類名下方附加一個標(biāo)記值{abstract},如圖9.12所示。圖下方的兩個折角矩形是模型元素“筆記”的符號,其中的文字是注釋,分別說明兩個子類的操作drive的功能。抽象類通常都具有抽象操作。抽象操作僅用來指定該類的所有子類應(yīng)具有哪些行為。抽象操作的圖示方法與抽象類相似,在操作標(biāo)記后面跟隨一個性質(zhì)串{abstract}。98需要特別說明的是,沒有具體對象的類稱為抽象類。抽象類通常作為98圖9.12抽象類示例993299與抽象類相反的類是具體類,具體類有自己的對象,并且該類的操作都有具體的實現(xiàn)方法。圖9.13給出一個比較復(fù)雜的類圖示例,這個例子綜合應(yīng)用了前面講過的許多概念和圖示符號。10033100圖9.13復(fù)雜類圖示例10134101(2)受限泛化可以給泛化關(guān)系附加約束條件,以進(jìn)一步說明該泛化關(guān)系的使用方法或擴充方法,這樣的泛化關(guān)系稱為受限泛化。預(yù)定義的約束有4種:多重、不相交、完全和不完全。這些約束都是語義約束。多重繼承指的是,一個子類可以同時多次繼承同一個上層基類,例如圖9.14中的水陸兩用類繼承了兩次交通工具類。與多重繼承相反的是不相交繼承,即一個子類不能多次繼承同一個基類(這樣的基類相當(dāng)于C++語言中的虛基類)。如果圖中沒有指定{多重}約束,則是不相交繼承,一般的繼承都是不相交繼承。102(2)受限泛化35102圖9.14多重繼承示例10336103完全繼承指的是父類的所有子類都已在類圖中窮舉出來了,圖示符號是指定{完全}約束。不完全繼承與完全繼承恰好相反,父類的子類并沒有都窮舉出來,隨著對問題理解的深入,可不斷補充和維護,這為日后系統(tǒng)的擴充和維護帶來很大方便。不完全繼承是一般情況下默認(rèn)的繼承關(guān)系。104完全繼承指的是父類的所有子類都已在類圖中窮舉出來了,圖示符號1044、依賴和細(xì)化(1)依賴關(guān)系描述兩個模型元素(類、用例等)之間的語義連接關(guān)系:其中一個模型元素是獨立的,另一個模型元素不是獨立的,它依賴于獨立的模型元素。獨立類不獨立版類標(biāo)簽:說明依賴的種類例如:友元關(guān)系使得類B的操作可以使用A類中私有的或保護的成員。1054、依賴和細(xì)化獨立類不獨立版類標(biāo)簽:說明依賴的種類例如:友元105(2)細(xì)化關(guān)系當(dāng)對同一個事物在不同抽象層次上描述時,這些描述之間具有細(xì)化關(guān)系。假設(shè)兩個模型元素A和B描述同一個事物,它們的區(qū)別是抽象層次不同,如果B是在A的基礎(chǔ)上的更詳細(xì)的描述,則稱B細(xì)化了A,或稱A細(xì)化成了B。細(xì)化用來協(xié)調(diào)不同階段模型之間的關(guān)系,表示各個開發(fā)階段不同抽象層次的模型之間的相關(guān)性,常常用于跟蹤模型的演變BA106(2)細(xì)化關(guān)系BA39106ClassNameAttributesMethodsClassClassNameAttributesMethodsClass-&-Object表示屬于該類的對象也可對類和對象用有區(qū)別的畫法:107ClassNameAttributesMethodsCla107動態(tài)模型表示瞬時的、行為化的系統(tǒng)的“控制”性質(zhì),它規(guī)定了對象模型中的對象的合法變化序列。一旦建立起對象模型之后,就需要考察對象的動態(tài)行為。所有對象都具有自己的生命周期(或稱為運行周期)。對一個對象來說,生命周期由許多階段組成,在每個特定階段中,都有適合該對象的一組運行規(guī)律和行為規(guī)則,用以規(guī)范該對象的行為。生命周期中的階段也就是對象的狀態(tài)。動態(tài)模型:表示系統(tǒng)瞬時的控制性質(zhì)§5動態(tài)模型108動態(tài)模型表示瞬時的、行為化的系統(tǒng)的“控制”性質(zhì),它規(guī)定了對象108狀態(tài)1do/活動1狀態(tài)2do/活動2事件[條件]/動作其中:狀態(tài)內(nèi)部的“活動”不引起狀態(tài)轉(zhuǎn)移;箭頭上的“動作”指狀態(tài)轉(zhuǎn)移時要執(zhí)行的動作。注:當(dāng)描述循環(huán)運行過程時,通常不關(guān)心是怎樣啟動的。三要素:①事件:引發(fā)object狀態(tài)改變的控制信息(瞬時)。②狀態(tài):即

object的

attributes所處的情形(可持續(xù))。③活動:Object要達(dá)到某種status所做的操作(耗時)。狀態(tài)圖109狀態(tài)1do/活動1狀態(tài)2do/活動2事件[條件]/動作其109通常,用UML提供的狀態(tài)圖來描繪對象的狀態(tài)、觸發(fā)狀態(tài)轉(zhuǎn)換的事件以及對象的行為(對事件的響應(yīng))。每個類的動態(tài)行為用一張狀態(tài)圖來描繪,各個類的狀態(tài)圖通過共享事件合并起來,從而構(gòu)成系統(tǒng)的動態(tài)模型。也就是說,動態(tài)模型是基于事件共享而互相關(guān)聯(lián)的一組狀態(tài)圖的集合。110通常,用UML提供的狀態(tài)圖來描繪對象的狀態(tài)、觸發(fā)狀態(tài)轉(zhuǎn)換的事110閑置撥號通話斷線撥號音do:響撥號音超時do:響蜂鳴音存儲的信息do:播放信息接通中do:試接通振鈴do:振鈴忙音do:響忙音拿起聽筒數(shù)字?jǐn)?shù)字有效號碼已接通受話人回話受話人掛斷電話掛斷電話超時掛斷電話超時無效號碼信息播完占線例:電話的狀態(tài)圖111閑置撥號通話斷線撥號音超時存儲的信息接通中振鈴忙111UML提供的用例圖也是建立功能模型的強有力工具。在UML中把用用例圖建立起來的系統(tǒng)模型稱為用例模型,一個用例模型由若干幅用例圖組成?!?功能模型功能模型:表明系統(tǒng)應(yīng)該做什么通常的表示方法:數(shù)據(jù)流圖(DFD)用例圖僅僅從參與者使用系統(tǒng)的角度描述系統(tǒng),不反映內(nèi)部的處理方式。因此用例圖定義的是系統(tǒng)的功能需求。其主要目的是以一種可視化的方式理解系統(tǒng)的功能需求。

一幅用例圖包含的模型元素有系統(tǒng)、行為者、用例及用例之間的關(guān)系。112UML提供的用例圖也是建立功能模型的強有力工具。在UML中把112用例建模的主要步驟:首先定義一個系統(tǒng);并在該系統(tǒng)中確定執(zhí)行者;確定用例,描述每一個用例;確定關(guān)系(包括用例與執(zhí)行者之間的關(guān)系,執(zhí)行者之間的關(guān)系,用例之間的關(guān)系);最后確認(rèn)所建的模型。113用例建模的主要步驟:461131.系統(tǒng)系統(tǒng)被看作是一個提供用例的黑盒子,內(nèi)部如何工作、用例如何實現(xiàn),這些對于建立用例模型來說都是不重要的。代表系統(tǒng)的方框的邊線表示系統(tǒng)的邊界,用于劃定系統(tǒng)的功能范圍,定義了系統(tǒng)所具有的功能。描述該系統(tǒng)功能的用例置于方框內(nèi),代表外部實體的行為者置于方框外。9.6.1用例圖1141.系統(tǒng)9.6.1用例圖47114例如:115例如:48115簽定一份保險單客戶保險銷售人員銷售統(tǒng)計客戶統(tǒng)計某保險業(yè)務(wù)的用例圖又如:116簽定一份客戶保險銷銷售統(tǒng)計客戶統(tǒng)計某保險業(yè)務(wù)的用例圖又如:41162.用例一個用例是可以被行為者感受到的、系統(tǒng)的一個完整的功能。在UML中把用例定義成系統(tǒng)完成的一系列動作,動作的結(jié)果能被特定的行為者察覺到。這些動作除了完成系統(tǒng)內(nèi)部的計算與工作外,還包括與一些行為者的通信。用例通過關(guān)聯(lián)與行為者連接,關(guān)聯(lián)指出一個用例與哪些行為者交互,這種交互是雙向的。用例具有下述特征:(1)用例代表某些用戶可見的功能,實現(xiàn)一個具體的用戶目標(biāo);1172.用例50117(2)用例總是被行為者啟動的,并向行為者提供可識別的值;(3)用例必須是完整的。注意,用例是一個類,它代表一類功能而不是使用該功能的某個具體實例。用例的實例是系統(tǒng)的一種實際使用方法,通常把用例的實例稱為腳本。腳本是系統(tǒng)的一次具體執(zhí)行過程,例如,在自動售貨機系統(tǒng)中,張三投入硬幣購買礦泉水,系統(tǒng)收到錢后把礦泉水送出來,上述過程就是一個腳本;李四投幣買可樂,但是可樂已賣完了,于是系統(tǒng)給出提示信息并把錢退還給李四,這個過程是另一個腳本。118(2)用例總是被行為者啟動的,并向行為者提供可識別的值;51183.行為者行為者是指與系統(tǒng)交互的人或其他系統(tǒng),它代表外部實體。使用用例并且與系統(tǒng)交互的任何人或物都是行為者。行為者代表一種角色,而不是某個具體的人或物。事實上,一個具體的人可以充當(dāng)多種不同角色。1193.行為者52119在用例圖中用直線連接行為者和用例,表示兩者之間交換信息,稱為通信聯(lián)系。行為者觸發(fā)(激活)用例,并與用例交換信息。單個行為者可與多個用例聯(lián)系;反之,一個用例也可與多個行為者聯(lián)系。對于同一個用例而言,不同行為者起的作用也不同??梢园研袨檎叻殖芍餍袨檎吆透毙袨檎?,還可分成主動行為者和被動行為者。實踐表明,行為者對確定用例是非常有用的。面對一個大型、復(fù)雜的系統(tǒng),要列出用例清單往往很困難,可以先列出行為者清單,再針對每個行為者列出它的用例。這樣做可以比較容易地建立起用例模型。120在用例圖中用直線連接行為者和用例,表示兩者之間交換信息,稱為1204.用例之間的關(guān)系UML用例之間主要有擴展和使用兩種關(guān)系,它們是泛化關(guān)系的兩種不同形式。(1)擴展關(guān)系向一個用例中添加一些動作后構(gòu)成了另一個用例,這兩個用例之間的關(guān)系就是擴展關(guān)系,后者繼承前者的

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論