UML中關係圖解

最近在教軟件工程項目實踐,就又仔細瞭解了下UML中各種關係的意義,雖然有點簡單,但是有些概念還是經常被混淆的,寫在這裏是爲了加深印象。

關係列表:

  1. 繼承關係(Generalization);
  2. 實現關係(Realization);
  3. 依賴關係(Dependency);
  4. 關聯關係(Association);
  5. 有方向的關聯(DirectedAssociation);
  6. 聚合關係(Aggregation);
  7. 組合關係(Composition);

繼承關係(Generalization):

Class B繼承與Class A

 

繼承指的是一個類(稱爲子類、子接口)繼承另外的一個類(稱爲父類、父接口)的功能,並可以增加它自己的新功能的能力,繼承是類與類或者接口與接口之間最常見的關係之一;在Java中此類關係通過關鍵字extends明確標識,在設計時一般沒有爭議性;

實現關係(Realization):

Class A實現了Interface A

 

實現指的是一個class類實現interface接口(可以是多個)的功能;實現是類與接口之間最常見的關係之一;在Java中此類關係通過關鍵字implements明確標識,在設計時一般沒有爭議性;

依賴關係(Dependency):

ClassA依賴於ClassB

 

可以簡單的理解,就是一個類A使用到了另一個類B,而這種使用關係是具有偶然性的、臨時性的、非常弱的,但是B類的變化會影響到A;表現在代碼層面,爲類B作爲參數被類A在某個method方法中使用;

關聯關係(Association):

ClassA與ClassB相互關聯

 

這裏的關聯關係分的比較細,把相互關聯和有方向的關聯區分開了,相互他體現的是兩個類、或者類與接口之間語義級別的一種強依賴關係,是一種長期的穩定的關係;表現在代碼層面,爲被關聯類以類屬性的形式出現在關聯類中,也可能是關聯類引用了一個類型爲被關聯類的全局變量;

有方向的關聯(DirectedAssociation):

ClassA關聯於ClassB

 

是關聯的一種特別形式,是單向的;表現在代碼層面,爲被關聯類B以類屬性的形式出現在關聯類A中,也可能是關聯類A引用了一個類型爲被關聯類B的全局變量;

聚合關係(Aggregation):

計算機 has-a cpu

 

聚合是關聯關係的一種特例,他體現的是整體與部分、擁有的關係,即has-a的關係,此時整體與部分之間是可分離的,他們可以具有各自的生命週期,部分可以屬於多個整體對象,也可以爲多個整體對象共享;比如計算機與CPU;表現在代碼層面,和關聯關係是一致的,只能從語義級別來區分;

組合關係(Composition):

孕婦 contains-a 胎兒

 

組合也是關聯關係的一種特例,他體現的是一種contains-a的關係,這種關係比聚合更強,也稱爲強聚合;他同樣體現整體與部分間的關係,但此時整體與部分是不可分的,整體的生命週期結束也就意味着部分的生命週期結束;孕婦死了胎兒自然也就死了;表現在代碼層面,和關聯關係是一致的,只能從語義級別來區分;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章