UML基礎(chǔ)教程_入門_第1頁
UML基礎(chǔ)教程_入門_第2頁
UML基礎(chǔ)教程_入門_第3頁
UML基礎(chǔ)教程_入門_第4頁
UML基礎(chǔ)教程_入門_第5頁
已閱讀5頁,還剩63頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、UML- 1 -UML- 1 -UML 基礎(chǔ)教程基礎(chǔ)教程UML- 2 -UML- 2 -1. 前言前言1.1前言前言1.2UML概述概述1.3UML事物事物1.4UML關(guān)系關(guān)系1.5各各UML圖及特征圖及特征1.6各各UML圖的關(guān)系圖的關(guān)系1.7UML語法語法1.8習(xí)題習(xí)題2. 用例圖用例圖2.1用例圖用例圖概要概要2.2用例圖中的事物及解釋用例圖中的事物及解釋2.3用例圖中的關(guān)系及解釋用例圖中的關(guān)系及解釋2.4例子例子2.5習(xí)題習(xí)題3. 類圖類圖3.1類圖概要類圖概要3.2類圖中的事物及解釋類圖中的事物及解釋3.3類圖中的關(guān)系及解釋類圖中的關(guān)系及解釋3.4類圖與代碼的映射類圖與代碼的映射3.

2、5類圖例子類圖例子3.6習(xí)題習(xí)題4. 順序圖順序圖4.1概要概要4.2順序圖中的事物及解釋順序圖中的事物及解釋4.3順序圖與用例圖和類圖的關(guān)系順序圖與用例圖和類圖的關(guān)系4.4順序圖例子順序圖例子4.5 練習(xí)題練習(xí)題5. 協(xié)作圖協(xié)作圖5.1概要概要5.2協(xié)作圖中的事物及解釋協(xié)作圖中的事物及解釋5.3協(xié)作圖中的關(guān)系及解釋協(xié)作圖中的關(guān)系及解釋UML- 3 -UML- 3 -5.4對消息標(biāo)簽的詳細(xì)講解對消息標(biāo)簽的詳細(xì)講解5.5協(xié)作圖例子協(xié)作圖例子5.6協(xié)作圖與順序圖的區(qū)別和聯(lián)系協(xié)作圖與順序圖的區(qū)別和聯(lián)系5.7練習(xí)題練習(xí)題6. 狀態(tài)圖狀態(tài)圖6.1狀態(tài)圖概要狀態(tài)圖概要6.2狀態(tài)圖的組成狀態(tài)圖的組成6.3狀

3、態(tài)圖中的事物及解釋狀態(tài)圖中的事物及解釋6.4狀態(tài)的可選活動表狀態(tài)的可選活動表6.5簡單的例子簡單的例子:對象的狀態(tài)圖對象的狀態(tài)圖6.6復(fù)雜的例子復(fù)雜的例子:網(wǎng)上銀行登陸系統(tǒng)網(wǎng)上銀行登陸系統(tǒng)6.7練習(xí)練習(xí)7. 活動圖活動圖7.1活動圖概要活動圖概要7.2活動圖活動圖事物事物7.3活動圖關(guān)系活動圖關(guān)系7.4活動圖實例活動圖實例7.5活動圖練習(xí)活動圖練習(xí)8. 構(gòu)件圖構(gòu)件圖8.1構(gòu)件圖概要構(gòu)件圖概要8.2構(gòu)件圖中的事物及解釋構(gòu)件圖中的事物及解釋8.3構(gòu)件圖中的關(guān)系及解釋構(gòu)件圖中的關(guān)系及解釋8.4構(gòu)件圖的例子構(gòu)件圖的例子8.5習(xí)題習(xí)題9. 部署圖部署圖9.1部署圖概要部署圖概要9.2部署圖中的事物及解釋

4、部署圖中的事物及解釋9.3部署圖中的關(guān)系及解釋部署圖中的關(guān)系及解釋9.4部署圖的例子部署圖的例子9.5關(guān)于部署圖與構(gòu)件圖關(guān)于部署圖與構(gòu)件圖9.6習(xí)題習(xí)題 附錄附錄UML- 4 -1.1 前言前言 本資料對UML1.5各種模型圖的構(gòu)成和功能進(jìn)行說明,通過本資料的學(xué)習(xí)達(dá)到可以讀懂UML模型圖的目的。本資料不涉及模型圖作成的要點等相關(guān)知識。1.2 UML概述概述1.2.1 UML簡介簡介 UML (Unified Modeling Language)為面向?qū)ο筌浖O(shè)計提供統(tǒng)一的、標(biāo)準(zhǔn)的、可視化的建模語言。適用于描述以用例為驅(qū)動,以體系結(jié)構(gòu)為中心的軟件設(shè)計的全過程。 UML的定義包括UML語義和UML

5、表示法兩個部分。 (1) UML語義語義:UML對語義的描述使開發(fā)者能在語義上取得一致認(rèn)識,消除了因人 而異的表達(dá)方法所造成的影響。 (2) UML表示法表示法:UML表示法定義UML符號的表示法,為開發(fā)者或開發(fā)工具使用這 些圖形符號和文本語法為系統(tǒng)建模提供了標(biāo)準(zhǔn)。1.2.2 UML模型圖的構(gòu)成模型圖的構(gòu)成 事物事物(Things):UML模型中最基本的構(gòu)成元素,是具有代表性的成分的抽象 關(guān)系關(guān)系(Relationships):關(guān)系把事物緊密聯(lián)系在一起 圖圖(Diagrams ):圖是事物和關(guān)系的可視化表示UML- 5 -1.3 UML事物事物 UML包含4種事物:構(gòu)件事物 行為事物 分組事物

6、 注釋事物1.3.1構(gòu)件事物構(gòu)件事物: UML模型的靜態(tài)部分,描述概念或物理元素 它包括以下幾種:類類:具有相同屬性相同操作 相同關(guān)系相同語義的對象的描述接口接口:描述元素的外部可見行為,即服務(wù)集合的定義說明協(xié)作協(xié)作:描述了一組事物間的相互作用的集合用例用例:代表一個系統(tǒng)或系統(tǒng)的一部分行為,是一組動作序列的集合構(gòu)件構(gòu)件:系統(tǒng)中物理存在,可替換的部件節(jié)點節(jié)點:運行時存在的物理元素 另外,參與者、信號應(yīng)用、文檔庫、頁表等都是上述基本事物的變體1.3.2行為事物行為事物:UML模型圖的動態(tài)部分,描述跨越空間和時間的行為交互交互:實現(xiàn)某功能的一組構(gòu)件事物之間的消息的集合,涉及消息、動作序列、鏈接狀態(tài)機

7、狀態(tài)機:描述事物或交互在生命周期內(nèi)響應(yīng)事件所經(jīng)歷的狀態(tài)序列1.3.3分組事物分組事物: UML模型圖的組織部分,描述事物的組織結(jié)構(gòu)包包:把元素組織成組的機制1.3.4注釋事物注釋事物: UML模型的解釋部分,用來對模型中的元素進(jìn)行說明,解釋注解注解:對元素進(jìn)行約束或解釋的簡單符號UML- 6 -1.4 UML關(guān)系關(guān)系1.4.1依賴依賴 依賴(dependency)是兩個事物之間的語義關(guān)系,其中一個事物(獨立事物)發(fā)生變化, 會影響到另一個事物(依賴事物)的語義1.4.2關(guān)聯(lián)關(guān)聯(lián) 關(guān)聯(lián)(association)是一種結(jié)構(gòu)關(guān)系,它指明一個事物的對象與另一個事物的對象間 的聯(lián)系1.4.3泛化泛化 泛

8、化(generalization)是一種特殊/一般的關(guān)系。也可以看作是常說的繼承關(guān)系1.4.4實現(xiàn)實現(xiàn) 實現(xiàn)(realization)是類元之間的語義關(guān)系,其中的一個類元指定了由另一個類元保 證執(zhí)行的契約UML- 7 -1.5 各各UML圖及特征圖及特征1.5.1用例圖用例圖( Use Case Diagram ) 用例圖是從用戶角度描述系統(tǒng)功能, 是用戶所能觀察到的系統(tǒng)功能的模型圖,用例是系統(tǒng)中的一個功能單元 類圖描述系統(tǒng)中類的靜態(tài)結(jié)構(gòu)。不僅定義系統(tǒng)中的類,表示類之間的聯(lián)系如關(guān)聯(lián)、依賴、聚合等,也包括類的內(nèi)部結(jié)構(gòu)(類的屬性和操作) 類圖是以類為中心來組織的,類圖中的其他元素或?qū)儆谀硞€類或與類

9、相關(guān)聯(lián) 1.5.2 類圖類圖(Class Diagram)UML- 8 -1.5 各各UML圖及特征圖及特征1.5.3 對象圖對象圖( Object Diagram )對象圖是類圖的實例,幾乎使用與類圖完全相同的標(biāo)識。他們的不同點在于對象圖顯示類的多個對象實例,而不是實際的類1.5.4 順序圖順序圖(Sequence Diagram)順序圖顯示對象之間的動態(tài)合作關(guān)系,它強調(diào)對象之間消息發(fā)送的順序,同時顯示對象之間的交互 順序圖的一個用途是用來表示用例中的行為順序。當(dāng)執(zhí)行一個用例行為時,順序圖中的每條消息對應(yīng)了一個類操作或引起狀態(tài)轉(zhuǎn)換的觸發(fā)事件 UML- 9 -1.5 各各UML圖及特征圖及特征

10、1.5.5 協(xié)作圖協(xié)作圖(Collaboration Diagram) 協(xié)作圖描述對象間的協(xié)作關(guān)系,協(xié)作圖跟順序圖 相似,顯示對象間的動態(tài)合作關(guān)系。除顯示信息交換外,協(xié)作圖還顯示對象以及它們之間的關(guān)系. 協(xié)作圖的一個用途是表示一個類操作的實現(xiàn) 1.5.6 狀態(tài)圖狀態(tài)圖(State Chart Diagram) 狀態(tài)圖是一個類對象所可能經(jīng)歷的所有歷程的模型圖。狀態(tài)圖由對象的各個狀態(tài)和連接這些狀態(tài)的轉(zhuǎn)換組成 Available Locked Sold 初始狀態(tài) assigned to subscription lock time out unlock buy 狀態(tài) exchange 轉(zhuǎn)換 觸發(fā)器事

11、件 UML- 10 -1.5 各各UML圖及特征圖及特征1.5.7 活動圖活動圖(Activity Diagram)活動圖是狀態(tài)圖的一個變體,用來描述執(zhí)行算法的工作流程中涉及的活動活動圖描述了一組順序的或并發(fā)的活動 1.5.8 構(gòu)構(gòu)件圖件圖(Component Diagram)構(gòu)件圖為系統(tǒng)的構(gòu)件建模型構(gòu)件即構(gòu)造應(yīng)用的軟件單元還包括各構(gòu)件之間的依賴關(guān)系,以便通過這些依賴關(guān)系來估計對系統(tǒng)構(gòu)件的修改給系統(tǒng)可能帶來的影響 UML- 11 -1.5 各各UML圖及特征圖及特征1.5.9 部署部署圖圖(Deployment Diagram)部署視圖描述位于節(jié)點實例上的運行構(gòu)件實例的安排。節(jié)點是一組運行資源

12、,如計算機、設(shè)備或存儲器。這個視圖允許評估分配結(jié)果和資源分配類圖順序圖需求分析需求分析BD Base Design 基本設(shè)計基本設(shè)計FD Functional Design 功能設(shè)計功能設(shè)計DD Detailed Design 詳細(xì)設(shè)計詳細(xì)設(shè)計類圖順序圖用例圖用例文檔用例圖順序圖主要圖之間的關(guān)系主要圖之間的關(guān)系1.6 各各UML圖的關(guān)系圖的關(guān)系UML- 12 -1.7 UML語法描述語法描述節(jié)點是在運行時存在的物理元素交互它由在特定語境中共同完成一定任務(wù)的一組對象間交換的消息組成狀態(tài)機它描述了一個對象或一個交互在生命期內(nèi)響應(yīng)事件所經(jīng)歷的狀態(tài)序列包把元素組織成組的機制注釋事物是UML模型的解釋部

13、分依賴一條可能有方向的虛線關(guān)聯(lián)一條實線,可能有方向泛化一條帶有空心箭頭的實線實現(xiàn)一條帶有空心箭頭的虛線NewClassInterfaceusecase類是對一組具有相同屬性、相同操作、相同關(guān)系和相同語義的對象的描述對象接口是描述了一個類或構(gòu)件的一個服務(wù)的操作集協(xié)作定義了一個交互,它是由一組共同工作以提供某種協(xié)作行為的角色和其他元素構(gòu)成的一個群體用例是對一組動作序列的描述主動類對象至少擁有一個進(jìn)程或線程的類構(gòu)件是系統(tǒng)中物理的、可替代的部件參與者在系統(tǒng)外部與系統(tǒng)直接交互的人或事物actorNewProcessorstateNewPackagecomponetUML- 13 -1.8習(xí)題習(xí)題 判斷題

14、1、UML中一共有九種圖:它們是用例圖、類圖、對象圖、順序圖、協(xié)作圖、狀態(tài)圖、活動圖、構(gòu)件圖、部署圖 OK2、用例圖是從程序員角度來描述系統(tǒng)的功能 NO3、類圖是描述系統(tǒng)中類的靜態(tài)結(jié)構(gòu),對象圖是描述系統(tǒng)中類的動態(tài)結(jié)構(gòu) NO4、活動圖和狀態(tài)圖用來描述系統(tǒng)的動態(tài)行為 OK5、協(xié)作圖的一個用途是表示一個類操作的實現(xiàn) OK 選擇題6、請在下面選項目中選出兩種可以互相轉(zhuǎn)換的圖 ab (a) 順序圖 (b)協(xié)作圖 (c) 活動圖 (d) 狀態(tài)圖 解釋:協(xié)作圖與順序圖類似;活動圖是狀態(tài)圖的一個變體7、下面哪些圖可用于BD階段 acd (a)用例圖 (b)構(gòu)件圖 (c)類圖 (d)順序圖 答案:1.正確 2.

15、錯誤 3.錯誤 4.正確 5.正確 6. (a)(b) 7.(a)(c)(d)UML- 14 -2.1 用例圖用例圖概要概要 事物名稱解釋UML表示參與者(Actor)在系統(tǒng)外部與系統(tǒng)直接交互的人或事物(如另一個計算機系統(tǒng)或一些可運行的進(jìn)程)。我們需要注意的是:1.參與者是角色(role)而不是具體的人,它代表了參與者在與系統(tǒng)打交道的過程中所扮演的角色。所以在系統(tǒng)的實際運作中,一個實際用戶可能對應(yīng)系統(tǒng)的多個參與者。不同的用戶也可以只對應(yīng)于一個參與者,從而代表同一參與者的不同實例。2.參與者作為外部用戶(而不是內(nèi)部)與系統(tǒng)發(fā)生交互作用,是它的主要特征。3.在后面的順序圖等中出現(xiàn)的“參與者”,與此

16、概念相同,但具體指代的含義,視具體情況而定。用例(Use Case)系統(tǒng)外部可見的一個系統(tǒng)功能單元。系統(tǒng)的功能由系統(tǒng)單元所提供,并通過一系列系統(tǒng)單元與一個或多個參與者之間交換的消息所表達(dá) 。創(chuàng)建新用例,確認(rèn)候選用例和劃分用例范圍的優(yōu)秀法則-“WAVE”測試(見附錄) 2.2 用例圖中的事物及解釋用例圖中的事物及解釋 用例圖是被稱為參與者的外部用戶所能觀察到的系統(tǒng)功能的模型圖。 (UML參考手冊) 用例圖列出系統(tǒng)中的用例和系統(tǒng)外的參與者,并顯示哪個參與者參與了哪個用例的執(zhí)行 (或稱為發(fā)起了哪個用例)。 用例圖多用于靜態(tài)建模階段(主要是業(yè)務(wù)建模和需求建模)。UML- 15 -關(guān)系解釋圖參與者與用例

17、之間的關(guān)系關(guān)聯(lián)表示參與者與用例之間的交互,通信途徑。(關(guān)聯(lián)有時候也用帶箭頭的實線來表示,這樣的表示能夠顯示地表明發(fā)起用例的是參與者。)用例之間的關(guān)系包含箭頭出發(fā)的用例為基用例;箭頭指向的用例為被包含的用例,稱為包含用例;包含用例是必選的,如果缺少包含用例,基用例就不完整;包含用例必須被執(zhí)行,不需要滿足某種條件;其執(zhí)行并不會改變基用例的行為。 include擴展箭頭出發(fā)的用例為基用例;箭頭指向的用例為被擴展的用例,稱為擴展用例;擴展用例是可選的,如果缺少擴展用例,不會影響到基用例的完整性;擴展用例在一定條件下才會執(zhí)行,并且其執(zhí)行會改變基用例的行為。參與者之間的關(guān)系泛化發(fā)出箭頭的事物“is a”箭

18、頭指向的事物。泛化關(guān)系是一般和特殊關(guān)系,發(fā)出箭頭的一方代表特殊的一方,箭頭指向的一方代表一般一方。特殊一方繼承了一般方的特性并增加了新的特性。extend2.3 用例圖中的關(guān)系及解釋用例圖中的關(guān)系及解釋UML- 16 -實例1 參與者之間的泛化關(guān)系 參與者參與者:經(jīng)理,安全主管,保安 用例用例:管理人事,批準(zhǔn)預(yù)算,批準(zhǔn)安全證書,監(jiān)視周邊 在參與者之間不存在泛化關(guān)系的情況下,各個參與者參與 用例的情況分別是:經(jīng)理參與用例管理人事和批準(zhǔn)預(yù)算;安全主管參與用例批準(zhǔn)安全證書;保安參與用例監(jiān)視周邊。由于安全主管與經(jīng)理,安全主管與保安之間泛化關(guān)系的存在,意味著安全主管可以擔(dān)任經(jīng)理和保安的角色,就能夠參與經(jīng)

19、理和保安參與的用例。這樣,安全主管就可以參與全部4個用例。但經(jīng)理或者保安卻不能擔(dān)任安全主管的角色,也就不能參與用例批準(zhǔn)安全證書。實例2 用例之間擴展和包含關(guān)系 用例的上下文是:短途旅行但汽車的油不足以應(yīng)付全部路程。那么為汽車加油的動作在旅行的每個場景(事件流)中都會出現(xiàn),不加油就不會完成旅行。吃飯則可以由司機決定是否進(jìn)行,不吃飯不會影響旅行的完成。2.4 例子例子UML- 17 -實例3. 航空售票的用例圖參與者(actor):clerk,監(jiān)督員,信用卡服務(wù)商,信息亭用例(use case): Buy tickets, Buy Subscription, Make charges, Surve

20、y sales參與者Clerk參與(或稱發(fā)起)Buy tickets和Buy Subscription 兩個用例(關(guān)聯(lián)關(guān)系)。這兩個用例的事件流都包含Make charges用例(包含關(guān)系)。系統(tǒng)由:Buy tickets, Buy Subscription, Make charges, Survey sales組成。該系統(tǒng)主要包含:Buy tickets, Buy Subscription, Make charges, Survey sales這幾個功能。該系統(tǒng)主要面向的用戶(參與者):clerk,監(jiān)督員,信用卡服務(wù)商,信息亭。 信息亭 Clerk Buy tickets Buy Subsc

21、ription 信用卡服務(wù)商 Make charges 監(jiān)督員 Survey sales 參與者 用例 Box Office 系統(tǒng) 關(guān)系 UML- 18 -右圖中的參與者有?ad (a) 1 (b) 2 (c) 3(d) 4右圖中的用例有?bc(a) 1(b) 2(c) 3(d) 42和3之間是什么關(guān)系?5和6呢?b(a) 擴展,包含(b) 包含,擴展5缺少了3仍然是個完整的用例?b(a) 是的(b) 不是4能夠參與2嗎?1能夠參與5嗎?b(a) 可以,不可以 (b) 不可以,可以習(xí)題答案:1、(a)(d) 2、(b)(c) 3、(b) 4、(b) 5、(b)2.5 習(xí)題習(xí)題UML- 19 -

22、UML- 19 -3.2 類圖中的事物及解釋類圖中的事物及解釋3.2.1 類類 從上到下分為三部分,分別是類名、屬性和操作。類名是必須有的 類如果有屬性,則每一個屬性都必須有一個名字,另外還可以有其它的描述信息,如可見性、數(shù)據(jù)類型、缺省值等 類如果有操作,則每一個操作也都有一個名字,其它可選的信息包括可見性、參數(shù)的名字、參數(shù)類型、參數(shù)缺省值和操作的返回值的類型等Account- balance : double = 1+ Deposit(amount : double) : int+ ComputeInterest() : double可見性可見性-代表private+代表public#代表p

23、rotected也可以使用圖形表示返回值類型返回值類型操作名稱操作名稱斜體為抽象操作缺省值缺省值類名類名斜體為抽象類屬性名稱屬性名稱參數(shù)列表參數(shù)列表3.1 類圖概要類圖概要 類圖以反映類的結(jié)構(gòu)(屬性、操作)以及類之間的關(guān)系為主要目的,描述了軟件系統(tǒng)的結(jié)構(gòu),是一種靜態(tài)建模方法 類圖中的“類”與面向?qū)ο笳Z言中的“類”的概念是對應(yīng)的,是對現(xiàn)實世界中的事物的抽象UML- 20 -UML- 20 -Shape(標(biāo)準(zhǔn)圖形)Shape+ Draw ()(變體圖形)接口Vehicle- fMaxSpeed : float+ Start() : int+ Stop() : int抽象類模版參數(shù)模版參數(shù)模版類3.

24、2 類圖中的事物及解釋類圖中的事物及解釋3.2.2 接口接口 一組操作的集合,只有操作的聲明而沒有實現(xiàn)3.2.3 抽象類抽象類 不能被實例化的類,一般至少包含一個抽象操作3.2.4 模版類模版類 一種參數(shù)化的類,在編譯時把模版參數(shù)綁定到不同的數(shù)據(jù)類型,從而產(chǎn)生不同的類UML- 21 -UML- 21 -2、聚合關(guān)系 聚合(Aggregation) : 表示has-a的關(guān)系,是一種不穩(wěn)定的包含關(guān)系。較強于一般關(guān)聯(lián),有整體與局部的關(guān)系,并且沒有了整體,局部也可單獨存在。如公司和員工的關(guān)系,公司包含員工,但如果公司倒閉,員工依然可以換公司。在類圖使用空心的菱形表示,菱形從局部指向整體。UML表示法表

25、示法3.3 類圖中的關(guān)系及解釋類圖中的關(guān)系及解釋3.3.1 關(guān)聯(lián)關(guān)系關(guān)聯(lián)關(guān)系1、關(guān)聯(lián)(Association) : 對象之間一種引用關(guān)系,比如客戶類與訂單類之間的關(guān)系。這種關(guān)系通常使用類的屬性表達(dá)。關(guān)聯(lián)又分為一般關(guān)聯(lián)、聚合關(guān)聯(lián)與組合關(guān)聯(lián)。后兩種在后面分析。在類圖使用帶箭頭的實線表示,箭頭從使用類指向被關(guān)聯(lián)的類??梢允菃蜗蚝碗p向。UML表示法表示法UML- 22 -UML- 22 -3、組合關(guān)系 組合(Composition) : 表示contains-a的關(guān)系,是一種強烈的包含關(guān)系。組合類負(fù)責(zé)被組合類的生命周期。是一種更強的聚合關(guān)系。部分不能脫離整體存在。如公司和部門的關(guān)系,沒有了公司,部門也

26、不能存在了;調(diào)查問卷中問題和選項的關(guān)系;訂單和訂單選項的關(guān)系。在類圖使用實心的菱形表示,菱形從局部指向整體。UML表示法表示法UML- 23 -UML- 23 -3.3.23.3.2依賴關(guān)系依賴關(guān)系依賴(Dependency):對象之間最弱的一種關(guān)聯(lián)方式,是臨時性的關(guān)聯(lián)。代碼中一般指由局部變量、函數(shù)參數(shù)、返回值建立的對于其他對象的調(diào)用關(guān)系。一個類調(diào)用被依賴類中的某些方法而得以完成這個類的一些職責(zé)。在類圖使用帶箭頭的虛線表示,箭頭從使用類指向被依賴的類。UML表示法表示法UML- 24 -UML- 24 -UML表示法表示法3.3.3 泛化關(guān)系泛化關(guān)系 泛泛化(generalization):表

27、示is-a的關(guān)系,是對象之間耦合度最大的一種關(guān)系,子類繼承父類的所有細(xì)節(jié)。直接使用語言中的繼承表達(dá)。在類圖中使用帶三角箭頭的實線表示,箭頭從子類指向父類。UML- 25 -UML- 25 -3.3.43.3.4 實現(xiàn)關(guān)系實現(xiàn)關(guān)系實現(xiàn)(Realization):在類圖中就是接口和實現(xiàn)的關(guān)系。在類圖中使用帶三角箭頭的虛線表示,箭頭從實現(xiàn)類指向接口。 UML表示法表示法UML- 26 -UML- 26 -C+代碼class Vehiclepublic: virtual int Start() = 0; virtual int Stop() = 0; virtual int Run(float fSp

28、eed) = 0;private: float fMaxSpeed;Java代碼public abstract class Vehicle public abstract int Start(); public abstract int Stop(); public abstract int Run(float fSpeed); private float fMaxSpeed;Vehicleabstract - fMaxSpeed : float+Start ()Stop ()Run (float fSpeed): int: int: int3.4 類圖與代碼的映射類圖與代碼的映射3.4.1

29、類的映射類的映射UML- 27 -UML- 27 -3.4.2 關(guān)聯(lián)關(guān)系的映射關(guān)聯(lián)關(guān)系的映射 C+代碼class Dialog private: Button btnOK; Button btnCancel; TextBox txtInfo;class Button;class TextBox;組合關(guān)系,代碼表現(xiàn)為Dialog的屬性有Button和TextBox的對象TextBoxButtonDialog- btnOK : Button- btnCancel : Button- txtInfo : TextBox3.4.3 泛化關(guān)系的映射泛化關(guān)系的映射Java代碼public class Sa

30、vingsAccount extends Account C+代碼class SavingsAccount : public Account ;UML- 28 -UML- 28 -C+代碼class Shape public: virtual void Draw() = 0;class Circle : public Shapepublic: void Draw();private; Point ptCenter; int nRadius;Java代碼public interface Shape public abstract void Draw();public class Circle i

31、mplements Shapepublic void Draw();private Point ptCenter;private int nRadius;Shape+ Draw ()Circle-ptCenternRadius: Point: int+ Draw ()Rectangle-ptUpperLeftnWidthnHeight: Point: int: int+ Drarw ()在C+語言里面,使用抽象類代替接口,使用泛化關(guān)系代替實現(xiàn)關(guān)系在Java語言里面,有相應(yīng)的關(guān)鍵字interface、implements3.4.4 實現(xiàn)關(guān)系的映射實現(xiàn)關(guān)系的映射 3.4.5 依賴關(guān)系的映射依賴關(guān)系

32、的映射綁定依賴TStack- size : int+ Push(elem : T) : int+ Pop() : int+ GetTop() : const T&IntStackFloatStackC+代碼templateclass Stack private: int size;public: int Push(T elem); int Pop(); const T& GetTop();typedef Stack FloatStack;C+代碼(編譯器生成)class FloatStack private: int size;public: int Push(float el

33、em); int Pop(); const float& GetTop();UML- 29 -UML- 29 -Graphics: 基本圖形和組合圖形的父類,聲明了所有圖形共同的操作,如Draw;也聲明了專用于組合圖形管理子圖形的操作,如Add、RemoveLine、Rectangle: 基本圖形類GroupGraphics: 組合圖形類,與父類有組合關(guān)系,從而可以組合所有圖形對象(基本圖形和組合圖形)泛化組合組合模式3.5 類圖例子類圖例子3.5.1 圖形編輯器圖形編輯器 圖形編輯器一般都具有一些基本圖形,如直線、矩形等,用戶可以直接使用基本圖形畫圖,也可以把基本圖形組合在一起創(chuàng)建復(fù)

34、雜圖形 如果區(qū)別對待基本圖形和組合圖形,會使代碼變得復(fù)雜,而且多數(shù)情況下用戶認(rèn)為二者是一樣的 組合模式可以用相同的方式處理兩種圖形UML- 30 -UML- 30 -3.5.2 演出售票系統(tǒng)演出售票系統(tǒng) 在用例驅(qū)動的開發(fā)過程中,通過分析各個用例及參與者得到類圖。分析用例圖的過程中需要根據(jù)面向?qū)ο蟮脑瓌t設(shè)計類和關(guān)系,根據(jù)用例的細(xì)節(jié)設(shè)計類的屬性和操作在這里只考慮以下三個用例:Buy tickets: 買個人票Buy Subscription: 買套票Make charges: 信用卡付款信息亭 Clerk Buy tickets Buy Subscription 信用卡服務(wù)商 Make charg

35、es 監(jiān)督員 Survey sales 參與者 用例 Box Office 關(guān)系 SubscriptionSeriesseries : intIndividualReservationTicketno : int3.60.13.60.110.110.1Reservationdate : DateCustomername : stringphone : string1.*11.*1Seatno : intcolomn : introw : intavailable : bool1111Performanceno : intdate : Datetime : Time0.*10.*1CreditC

36、ardServiceCharge(cardnumber, cost)kjoskShowAvailability(seatlist)DemandPayment(cost)PrintTickets(performance, seats)EjectCard()BoxOfficeRequest(count, performance)Select(seats)InsertCard(cardnumber, password)Authorized()用例圖用例圖類圖類圖使用泛化關(guān)系處理客戶購買個人票和套票兩種不同情況設(shè)計類的屬性和操作UML- 31 -UML- 31 -(1)哪兩個類之間存在組合關(guān)系哪兩個類

37、之間存在組合關(guān)系Menu、MenuItem MenuItem、CommandCommand、OpenCommandCommand、PasteCommand(2)OpenCommand和和PasteCommand是什么關(guān)系是什么關(guān)系組合泛化聚合沒關(guān)系Command+ Execute()OpenCommand+ Execute()PasteCommand+ Execute()MenuItem- command : Command*+ Click()1.*0.*1.*+executive0.*Menu+ Add(item : MenuItem)(3)編輯菜單編輯菜單(EditMenu)是一種菜單,下

38、面哪個圖較好的描述了二者之間的關(guān)系是一種菜單,下面哪個圖較好的描述了二者之間的關(guān)系(4)下面哪份代碼下面哪份代碼(C+)最接近于圖中對最接近于圖中對MenuItem的描述的描述EditMenuMenu+ Add(item : MenuItem) Menu+ Add(item : MenuItem)EditMenuEditMenuMenu+ Add(item : MenuItem) Menu+ Add(item : MenuItem)EditMenuclass MenuItemprivate: virtual void Click() =0;public: Command* command; c

39、lass MenuItempublic: virtual void Click() = 0;private: Command* command; class MenuItemprivate: virtual void Click() = 0; void undo();public: Command* command;class menuitempublic: virtual void Click() = 0;private: Command* command; 3.6 習(xí)題習(xí)題右圖描述了菜單(Menu)、菜單項(MenuItem)、抽象命令類(Command)和具體命令類(OpenComman

40、d, PasteCommand)之間的關(guān)系,完成1-4題UML- 32 -UML- 32 -右圖描述了圖形接口右圖描述了圖形接口(Graphics)、線段、線段(Segment)、矩形、矩形(Rectangle)、點、點(Point)和三維點和三維點(Point3D)之間的關(guān)系,之間的關(guān)系, 完成完成5-7題題(5)下面哪個關(guān)系沒有在圖中出現(xiàn)下面哪個關(guān)系沒有在圖中出現(xiàn) 關(guān)聯(lián) 泛化 實現(xiàn) 依賴(6)下面對圖中下面對圖中四處的多重性的描述哪個不正確四處的多重性的描述哪個不正確 0.* 1 0.* 1(7)下面哪份代碼下面哪份代碼(Java)最接近于圖中對最接近于圖中對Segment的描述的描述pu

41、blic class Segment implements Graphicsprivatc void Draw();public Point ptStart;public Point ptEnd;public class Segment extends Graphicspublic void Draw();private Point ptStart;private Point ptEnd;public class Segment implements Graphicsprivate Point ptStart;private Point ptEnd;public void Draw();pub

42、lic class segment implements graphicspublic void Draw();private Point ptStart;private Point ptEnd;Graphics+ Draw ()Segment-ptStartptEnd: Point: Point+ Draw ()Rectangle-ptUpperLeftnWidthnHeight: Point: int: int+ Drarw ()Point-xy: int: int+ Draw ()Point3D-xyz: int: int: int+ Draw ()UML- 33 -UML- 33 -U

43、ML- 33 -概要概要 順序圖用來表示用例中的行為順序。當(dāng)執(zhí)行一個用例行為時,順序圖中的每條消息對應(yīng)了一個類操作或狀態(tài)機中引起轉(zhuǎn)換的事件。 順序圖展示對象之間的交互,這些交互是指在場景或用例的事件流中發(fā)生的。 順序圖屬于動態(tài)建模。 順序圖的重點在消息序列上,也就是說,描述消息是如何在對象間發(fā)送和接收的。表示了對象之間傳送消息的時間順序。 瀏覽順序圖的方法是:從上到下查看對象間交換的消息。順序圖中的事物及解釋順序圖中的事物及解釋事物名稱解釋圖參與者與系統(tǒng)、子系統(tǒng)或類發(fā)生交互作用的外部用戶(參見用例圖定義)。對象順序圖的橫軸上是與序列有關(guān)的對象。對象的表示方法是:矩形框中寫有對象或類名,且名字下

44、面有下劃線。生命線坐標(biāo)軸縱向的虛線表示對象在序列中的執(zhí)行情況(即發(fā)送和接收的消息,對象的活動)這條虛線稱為對象的“生命線”。消息符號消息用從一個對象的生命線到另一個對象生命線的箭頭表示。箭頭以時間順序在圖中從上到下排列。UML- 34 -UML- 34 -UML- 34 -順序圖與用例圖和類圖的關(guān)系順序圖與用例圖和類圖的關(guān)系UML- 35 -UML- 35 -UML- 35 -順序圖例子順序圖例子簡單的例子簡單的例子從參與者到對象和從對象從參與者到對象和從對象到參與者之間發(fā)送的消息到參與者之間發(fā)送的消息從對象傳遞給另一個對從對象傳遞給另一個對象的消息象的消息在類圖中的類的在類圖中的類的對象對象

45、使用系統(tǒng)的使用系統(tǒng)的參與者,這參與者,這個系統(tǒng)是為個系統(tǒng)是為某個用例的某個用例的某個場景設(shè)某個場景設(shè)計的計的對象生命線表示從上到下對象生命線表示從上到下的時間順序,消息的時間順序,消息1在消息在消息2之前發(fā)生,消息之前發(fā)生,消息2在消息在消息3之前發(fā)生之前發(fā)生窄長方框用以強調(diào)這個窄長方框用以強調(diào)這個部分處于活動狀態(tài)部分處于活動狀態(tài)消息格式: operation (parameter list) 向哪個對象發(fā)消息實際上就是調(diào)用它的類中的操作,就是調(diào)用箭頭指向的對象所在類的 一個operation。例:訂單類發(fā)消息給客戶類調(diào)用客戶類中的“驗證客戶”操作UML- 36 -UML- 36 -UML-

46、36 -復(fù)雜的例子復(fù)雜的例子信息亭售票中心信用卡服務(wù)從這個例子中可以看出:Kjosk類中的操作有 Show Available (seat-list) Demand Payment (cost) printtickets (performance, seats) eject cardBox Office中的操作有 Request (count, performance) Select Seats Insert Card (Card Number) authorizedCredit Card Service類中的操作有 charge(card number, cost) 此圖是描述購票這個用例的

47、順序圖。顧客在信息亭與售票中心通話觸發(fā)了這個用例的執(zhí)行。順序圖中付款這個用例包括售票中心與信息亭和信用卡服務(wù)處使用消息進(jìn)行通信過程。此圖中存在的事物有:此圖中存在的事物有: 對象(信息亭 Kjosk ,售票中心 Box Office, 信用卡服務(wù) Credit Card Service ),生命線,消息符號。信息亭發(fā)Request (count, performance)消息給售票中心,表示調(diào)用售票中心類的Request (count, performance)操作,來查詢演出的信息。售票中心發(fā)Show Available(seat-list)消息給信息亭,表示調(diào)用信息亭類中的Show Ava

48、ilable(seat-list)操作,給出可用的座位表。UML- 37 -UML- 37 -UML- 37 -1 指出左圖中的參與者?1A B C D2 哪些是對象?234A B C D3 Server類調(diào)用了CreditService類中的什么操作?8A B C D4.5 練習(xí)題練習(xí)題1. A 2. B 3. B UML- 38 -UML- 38 -概要概要協(xié)作圖是一種交互圖,強調(diào)的是發(fā)送和接收消息的對象之間的組織結(jié)構(gòu),使用協(xié)作圖來說明系統(tǒng)的動態(tài)情況。 協(xié)作圖主要描述協(xié)作對象間的交互和鏈接,顯示對象、對象間的鏈接以及對象間如何發(fā)送消息。協(xié)作圖可以表示類操作的實現(xiàn)。UML- 38 -UML-

49、 38 -協(xié)作圖中的事物及解釋協(xié)作圖中的事物及解釋事物名稱解釋圖參與者發(fā)出主動操作的對象,負(fù)責(zé)發(fā)送初始消息,啟動一個操作。對象對象是類的實例,負(fù)責(zé)發(fā)送和接收消息,與順序圖中的符號相同,冒號前為對象名,冒號后為類名。消息流(由箭頭和標(biāo)簽組成)箭頭指示消息的流向,從消息的發(fā)出者指向接收者。標(biāo)簽對消息作說明,其中,順序號指出消息的發(fā)生順序,并且指明了消息的嵌套關(guān)系;冒號后面是消息的名字。Actorfirstbuton:button標(biāo)簽協(xié)作圖中的關(guān)系及解釋協(xié)作圖中的關(guān)系及解釋關(guān)系名稱解釋關(guān)系實例鏈接用線條來表示鏈接,鏈接表示兩個對象共享一個消息,位于對象之間或參與者與對象之間UML- 39 -UML-

50、 39 - 消息標(biāo)簽消息標(biāo)簽 消息標(biāo)簽的Format: 前綴 守衛(wèi)條件 序列表達(dá)式: 返回值 := 消息名 前綴的語法規(guī)則: 序列號,序列號,序列號 / (前綴用來同步線程,意思是在發(fā)送當(dāng)前消息之前指定序列號的消息被處理.例:1.1a, 1.1b/) 守衛(wèi)條件的語法規(guī)則: 條件短句 說明:條件短句通常用偽代碼或真正的程序語言來表示。 例:x=0 返回值和消息名:返回值表示一個消息的返回結(jié)果,消息名指出了消息的名字和所需參數(shù)。 例:x:=calc ( n ) 下面是一個完整的消息標(biāo)簽: 1.1a, 1.1b, 1.1c / x=0 1.2 *i:=1.n : x := calc( n ) 前綴

51、守衛(wèi)條件 序列表達(dá)式 返回值 := 消息名協(xié)作圖與順序圖的區(qū)別和聯(lián)系協(xié)作圖與順序圖的區(qū)別和聯(lián)系 協(xié)作圖和順序圖都表示出了對象間的交互作用,但是它們側(cè)重點不同。 順序圖清楚地表示了交互作用中的時間順序(強調(diào)時間),但沒有明確表示對象間的關(guān)系。 協(xié)作圖清楚地表示了對象間的關(guān)系(強調(diào)空間),但時間順序必須從順序號獲得。 協(xié)作圖和順序圖可以相互轉(zhuǎn)化。 (進(jìn)行協(xié)作圖和順序圖的比較,請參考練習(xí)題2)UML- 40 -協(xié)作圖例子協(xié)作圖例子1. 打印操作的協(xié)作圖actor發(fā)送Print消息給Computer,Computer發(fā)送Print消息給PrintServer,如果打印機空閑,PrintServer發(fā)送

52、Print消息給printer2.乘坐電梯的協(xié)作圖:button:Elevator Control:Queue:Elevator:Ordernew : Actor1 : GetElevator(floorid)1.1 *all queues : len:=Length()1.3: Invoke(job)1.2: Create( )2: nextjob:=Get.job( )Push( )圖中存在的事物有:圖中存在的事物有: 參與者 按鈕對象 電梯控制對象 命令對象 工作隊列 電梯對象圖中存在的關(guān)系有圖中存在的關(guān)系有: 鏈接 參與者需要乘坐電梯,他從系統(tǒng)外部按下按鈕,讓電梯到達(dá)他想去的樓層。此時

53、,電梯系統(tǒng)的操作被啟動,電梯控制對象以循環(huán)的方式檢查所有的電梯,從中選擇一個工作隊列長度最短的。然后,它創(chuàng)建一個作業(yè)命令,并將該命令放入對應(yīng)電梯的工作隊列,接著激活隊列。電梯對象并發(fā)運行,從它的隊列中選擇一個作業(yè)并執(zhí)行。電梯是一個活動對象,它與它的控制線程并發(fā)執(zhí)行。UML- 41 -5.7 練習(xí)題練習(xí)題請指出下面的消息標(biāo)簽各部分的內(nèi)容。1:display( A) A. 序列表達(dá)式:消息名 B.返回值:消息名 C.序列表達(dá)式:消息名mode=display 1.2.3.7: redraw( B) A.序列表達(dá)式 返回值 消息名 B.守衛(wèi)條件 序列表達(dá)式 消息名2 *n:=a . . z : pr

54、im:=nextPrim(prim)B A. 守衛(wèi)條件 序列表達(dá)式 消息名 B.序列表達(dá)式 返回值 消息名3.1 x0 : foo( B) A.序列表達(dá)式 守衛(wèi)條件 B.守衛(wèi)條件 消息名 C.序列表達(dá)式 消息名 1.1a, 1.1b/1.2 : continue( A) A. 前綴 序列表達(dá)式 消息名 B. 后綴 守衛(wèi)條件 消息名UML- 42 -:button:Elevator Control:Queue:Elevator:Ordernew : Actor1 : GetElevator(floorid)1.1 *all queues : len:=Length()2: nextjob:=Ge

55、t.job( )1.2: Create( )Push( )1.3: Invoke(job)3. 練習(xí)題答案1. A BBCA2. AA2. 請對比本章中的協(xié)作圖與其相應(yīng)的順序圖,做練習(xí)題。請在下圖中指出,循環(huán)計算各個電梯的工作隊列長度的消息的順序號。AA 1.1 B1.2 C1.3 D2請說明消息1.3所進(jìn)行的操作Invoke(job),應(yīng)屬于哪個類所具有的方法。AA Queue類 B ElevatorControl類 C Elevator類 D Button類 UML- 43 -6.1 狀態(tài)圖概要狀態(tài)圖概要6.1.1狀態(tài)圖狀態(tài)圖說明對象在它的生命期中響應(yīng)事件所經(jīng)歷的狀態(tài)序列,以及它們對那些事

56、件的響應(yīng)。6.1.2狀態(tài)圖用于狀態(tài)圖用于揭示Actor、類、子系統(tǒng)和組件的復(fù)雜特性。 為實時系統(tǒng)建模。 6.2 狀態(tài)圖的組成狀態(tài)圖的組成6.2.1狀態(tài)狀態(tài)對象的狀態(tài)是指在這個對象的生命期中的一個條件或狀況,在此期間對象將滿足某些條件、執(zhí)行某些活動,或等待某些事件。6.2.2轉(zhuǎn)移轉(zhuǎn)移轉(zhuǎn)移是由一種狀態(tài)到另一種狀態(tài)的遷移。這種轉(zhuǎn)移由被建模實體內(nèi)部或外部事件觸發(fā)。對一個類來說,轉(zhuǎn)移通常是調(diào)用了一個可以引起狀態(tài)發(fā)生重要變化的操作的結(jié)果。UML- 44 -狀態(tài)上格放置名稱,下格說明處于該狀態(tài)時,系統(tǒng)或?qū)ο笠龅墓ぷ?見可選活動表) 轉(zhuǎn)移轉(zhuǎn)移上標(biāo)出觸發(fā)轉(zhuǎn)移的事件表達(dá)式。如果轉(zhuǎn)移上未標(biāo)明事件,則表示在源狀態(tài)的

57、內(nèi)部活動執(zhí)行完畢后自動觸發(fā)轉(zhuǎn)移 開始初始狀態(tài)(一個)結(jié)束終態(tài)(可以多個)消息消息(屬性屬性)條件條件/動作動作6.3 狀態(tài)圖中的事物及解釋狀態(tài)圖中的事物及解釋轉(zhuǎn)換種類描述語法入口動作進(jìn)入某一狀態(tài)時執(zhí)行的動作entry/action出口動作離開某一狀態(tài)時執(zhí)行的動作exit/action外部轉(zhuǎn)換引起狀態(tài)轉(zhuǎn)換或自身轉(zhuǎn)換,同時執(zhí)行一個具體的動作,包括引起入口動作和出口動作被執(zhí)行的轉(zhuǎn)換e(a:T)exp/action內(nèi)部轉(zhuǎn)換引起一個動作的執(zhí)行但不引起狀態(tài)的改變或不引起入口動作或出口動作的執(zhí)行e(a:T)exp/action6.4 狀態(tài)的可選活動表狀態(tài)的可選活動表UML- 45 -6.5 例子例子 (1)

58、 對象的狀態(tài)圖對象的狀態(tài)圖 圖中包含以下狀態(tài)圖中包含以下狀態(tài)初始狀態(tài)Available狀態(tài)Locked狀態(tài)Sold狀態(tài) 狀態(tài)間的轉(zhuǎn)移狀態(tài)間的轉(zhuǎn)移初始狀態(tài)Available狀態(tài)票被預(yù)訂(lock):AvailableLocked預(yù)定后付款(buy):LockedSold預(yù)定解除(unlock):LockedAvailable預(yù)定過期(time out):LockedAvailable直接購買(assigned to):AvailableSold換其它票(exchang) ,該票重有效:SoldAvailable Available Locked Sold 初 始 狀 態(tài) assigned to

59、subscription lock time out unlock buy 狀 態(tài) exchange 轉(zhuǎn) 換 觸 發(fā) 器 事 件 UML- 46 - (2)網(wǎng)上銀行登陸系統(tǒng)網(wǎng)上銀行登陸系統(tǒng)登陸要求提交個人社會保險號登陸要求提交個人社會保險號(SSN)和密碼和密碼(PIN)經(jīng)驗證有效后登陸成功。經(jīng)驗證有效后登陸成功。登陸過程包括以下狀態(tài)登陸過程包括以下狀態(tài):初態(tài)初態(tài)(Initial state) 獲取社會保險號狀態(tài)獲取社會保險號狀態(tài)(Getting SSN)獲取密碼狀態(tài)獲取密碼狀態(tài)(Getting PIN)驗證狀態(tài)驗證狀態(tài)(Validating)拒絕狀態(tài)拒絕狀態(tài)(Rejecting)終態(tài)終態(tài) (

60、Final state)出發(fā)狀態(tài)動作到達(dá)狀態(tài)Initial state移動鼠標(biāo)到 SSNGetting SSNGetting SSN鍵入非tab鍵,顯示鍵入內(nèi)容Getting SSN鍵入tab鍵,或移動鼠標(biāo)到BINGetting PIN提交ValidatingGetting PIN鍵入非shift-tab鍵,顯示 “ * ”Getting PIN鍵入shift-tab鍵,或移動鼠標(biāo)到SSNGetting SSN提交Validating Validating驗證提交信息有效,狀態(tài)轉(zhuǎn)移Final state驗證提交信息無效,顯示錯誤信息Rejecting Rejecting退出Final state重試,清除無效的S

溫馨提示

  • 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

提交評論