UML類圖與類的關(guān)系詳解

虛線箭頭指向依賴;

實線箭頭指向關(guān)聯(lián);

虛線三角指向接口;

實線三角指向父類;

空心菱形能分離而獨立存在,是聚合;

實心菱形精密關(guān)聯(lián)不可分,是組合;

image

上面是UML的語法。

在畫類圖的時候,理清類和類之間的關(guān)系是重點。類的關(guān)系有泛化(Generalization)、實現(xiàn)(Realization)、依賴(Dependency)和關(guān)聯(lián)(Association)。其中關(guān)聯(lián)又分為一般關(guān)聯(lián)關(guān)系和聚合關(guān)系(Aggregation),合成關(guān)系(Composition)。下面我們結(jié)合實例理解這些關(guān)系。

基本概念

類圖(Class Diagram): 類圖是面向?qū)ο笙到y(tǒng)建模中最常用和最重要的圖,是定義其它圖的基礎(chǔ)。類圖主要是用來顯示系統(tǒng)中的類、接口以及它們之間的靜態(tài)結(jié)構(gòu)和關(guān)系的一種靜態(tài)模型。

類圖的3個基本組件:類名、屬性、方法。

image

泛化(generalization):表示is-a的關(guān)系,是對象之間耦合度最大的一種關(guān)系,子類繼承父類的所有細節(jié)。直接使用語言中的繼承表達。在類圖中使用帶三角箭頭的實線表示,箭頭從子類指向父類。

image

實現(xiàn)(Realization):在類圖中就是接口和實現(xiàn)的關(guān)系。這個沒什么好講的。在類圖中使用帶三角箭頭的虛線表示,箭頭從實現(xiàn)類指向接口。

image

依賴(Dependency):對象之間最弱的一種關(guān)聯(lián)方式,是臨時性的關(guān)聯(lián)。代碼中一般指由局部變量、函數(shù)參數(shù)、返回值建立的對于其他對象的調(diào)用關(guān)系。一個類調(diào)用被依賴類中的某些方法而得以完成這個類的一些職責(zé)。在類圖使用帶箭頭的虛線表示,箭頭從使用類指向被依賴的類。

image

關(guān)聯(lián)(Association) : 對象之間一種引用關(guān)系,比如客戶類與訂單類之間的關(guān)系。這種關(guān)系通常使用類的屬性表達。關(guān)聯(lián)又分為一般關(guān)聯(lián)、聚合關(guān)聯(lián)與組合關(guān)聯(lián)。后兩種在后面分析。在類圖使用帶箭頭的實線表示,箭頭從使用類指向被關(guān)聯(lián)的類??梢允菃蜗蚝碗p向。

image

聚合(Aggregation) : 表示has-a的關(guān)系,是一種不穩(wěn)定的包含關(guān)系。較強于一般關(guān)聯(lián),有整體與局部的關(guān)系,并且沒有了整體,局部也可單獨存在。如公司和員工的關(guān)系,公司包含員工,但如果公司倒閉,員工依然可以換公司。在類圖使用空心的菱形表示,菱形從局部指向整體。

image

組合(Composition) : 表示contains-a的關(guān)系,是一種強烈的包含關(guān)系。組合類負(fù)責(zé)被組合類的生命周期。是一種更強的聚合關(guān)系。部分不能脫離整體存在。如公司和部門的關(guān)系,沒有了公司,部門也不能存在了;調(diào)查問卷中問題和選項的關(guān)系;訂單和訂單選項的關(guān)系。在類圖使用實心的菱形表示,菱形從局部指向整體。

image

多重性(Multiplicity) : 通常在關(guān)聯(lián)、聚合、組合中使用。就是代表有多少個關(guān)聯(lián)對象存在。使用數(shù)字..星號(數(shù)字)表示。如下圖,一個割接通知可以關(guān)聯(lián)0個到N個故障單。

image

聚合和組合的區(qū)別

這兩個比較難理解,重點說一下。聚合和組合的區(qū)別在于:聚合關(guān)系是“has-a”關(guān)系,組合關(guān)系是“contains-a”關(guān)系;聚合關(guān)系表示整體與部分的關(guān)系比較弱,而組合比較強;聚合關(guān)系中代表部分事物的對象與代表聚合事物的對象的生存期無關(guān),一旦刪除了聚合對象不一定就刪除了代表部分事物的對象。組合中一旦刪除了組合對象,同時也就刪除了代表部分事物的對象。

實例分析

聯(lián)通客戶響應(yīng)OSS。系統(tǒng)有故障單、業(yè)務(wù)開通、資源核查、割接、業(yè)務(wù)重保、網(wǎng)絡(luò)品質(zhì)性能等功能模塊。現(xiàn)在我們抽出部分需求做為例子講解。

大家可以參照著類圖,好好理解。

image

1. 通知分為一般通知、割接通知、重保通知。這個是繼承關(guān)系。

2. NoticeService和實現(xiàn)類NoticeServiceImpl是實現(xiàn)關(guān)系。

3. NoticeServiceImpl通過save方法的參數(shù)引用Notice,是依賴關(guān)系。同時調(diào)用了BaseDao完成功能,也是依賴關(guān)系。

4. 割接通知和故障單之間通過中間類(通知電路)關(guān)聯(lián),是一般關(guān)聯(lián)。

5. 重保通知和預(yù)案庫間是聚合關(guān)系。因為預(yù)案庫可以事先錄入,和重保通知沒有必然聯(lián)系,可以獨立存在。在系統(tǒng)中是手工從列表中選擇。刪除重保通知,不影響預(yù)案。

6. 割接通知和需求單之間是聚合關(guān)系。同理,需求單可以獨立于割接通知存在。也就是說刪除割接通知,不影響需求單。

7. 通知和回復(fù)是組合關(guān)系。因為回復(fù)不能獨立于通知存在。也就是說刪除通知,該條通知對應(yīng)的回復(fù)也要級聯(lián)刪除。

經(jīng)過以上的分析,相信大家對類的關(guān)系已經(jīng)有比較好的理解了。大家有什么其它想法或好的見解,歡迎拍磚。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 在畫類圖的時候,理清類和類之間的關(guān)系是重點。類的關(guān)系有泛化(Generalization)、實現(xiàn)(Realizat...
    趙宇_ios閱讀 740評論 0 1
  • 在UML 2.0的13種圖形中,類圖是使用頻率最高的UML圖之一。Martin Fowler在其著作《UML Di...
    雷雷_zll閱讀 13,507評論 0 14
  • 在UML類圖中,常見的有以下幾種關(guān)系:泛化(Generalization),實現(xiàn)(Realization),關(guān)聯(lián)(...
    mocobk閱讀 1,356評論 0 1
  • 忘記了uml類圖連線之間的關(guān)系,記錄一下。 1. 關(guān)聯(lián)關(guān)系 關(guān)聯(lián)(Association)關(guān)系是類與類之間最常用的...
    cutieagain閱讀 1,996評論 0 2
  • UML類圖用來定義系統(tǒng)中的類,包括描述類的結(jié)構(gòu)和類之間的關(guān)系。類圖的主要作用于描述系統(tǒng)的靜態(tài)結(jié)構(gòu)。先看一張圖(圖片...
    Josaber閱讀 6,281評論 0 5

友情鏈接更多精彩內(nèi)容