1. 程式人生 > >UML圖之類圖(轉)

UML圖之類圖(轉)

中一 height position method 方法 分離 contain 基本 eal

基本概念

  類圖(Class Diagram): 類圖是面向對象系統建模中最常用和最重要的圖,是定義其它圖的基礎。類圖主要是用來顯示系統中的類、接口以及它們之間的靜態結構和關系的一種靜態模型。

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

            技術分享圖片

  屬性的完整表示方式是這樣的(中括號中的內容表示是可選的):可見性 名稱 :類型 [ = 缺省值]

  方法的完整表示方式如下(中括號中的內容表示是可選的):可見性 名稱(參數列表) [ : 返回類型]

  UML類圖中表示可見性的符號有三種:

  · + :表示public

  · - :表示private

  · #:表示protected(friendly也歸入這類)

類關系模型

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

          技術分享圖片

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

                技術分享圖片

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

          技術分享圖片

  關聯(Association) : 對象之間一種引用關系,比如客戶類與訂單類之間的關系。這種關系通常使用類的屬性表達。關聯又分為一般關聯、聚合關聯與組合關聯。後兩種在後面分析。在類圖使用帶箭頭的實線表示,箭頭從使用類指向被關聯的類。可以是單向和雙向。

              技術分享圖片

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

              技術分享圖片

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

            技術分享圖片

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

            技術分享圖片

聚合和組合的區別

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

實例分析

  UML的語法:

虛線箭頭指向依賴;

實線箭頭指向關聯;

虛線三角指向接口;

實線三角指向父類;

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

實心菱形精密關聯不可分,是組合;

        技術分享圖片

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

UML圖之類圖(轉)