1. 程式人生 > >UML中常見關係詳解(泛化、實現、依賴、關聯、組合、聚合)

UML中常見關係詳解(泛化、實現、依賴、關聯、組合、聚合)

UML中類與類,已經類與介面,介面與介面的關係有:泛化(generalization),關聯(association),依賴(dependency),實現(realization)這幾種。

  泛化(generalization)關係時指一個類(子類、子介面)繼承另外一個類(稱為父類、父介面)的功能,並可以增加它自己新功能的能力,繼承是類與類或者介面與介面最常見的關係,在Java中通過關鍵字extends來表示。

 

實現(realization)是指一個class實現interface介面(一個或者多個),表示類具備了某種能力,實現是類與介面中最常見的關係,在Java中通過implements關鍵字來表示。

 

依賴(dependency)關係也是表示類與類之間的連線,表示一個類依賴於另外一個類的定義,依賴關係時是單向的。簡單理解就是類A使用到了類B,這種依賴具有偶然性、臨時性,是非常弱的關係。但是類B的變化會影響到類A。舉個例子,如某人要過河,則人與船的關係就是依賴,人過河之後,與船的關係就解除了,因此是一種弱的連線。在程式碼層面,為類B作為引數被類A在某個方法中使用。

在java中,依賴表現為:區域性變數,方法中的引數和對靜態方法的呼叫。

 

關聯(association)關係表示類與類之間的連線,它使得一個類知道另外一個類的屬性和方法。

關聯可以使用單箭頭表示單向關聯,使用雙箭頭或者不適用箭頭表示雙向關聯,不建議使用雙向關聯,關聯有兩個端點,每個端點可以有一個基數,表示這個關聯的類可以有幾個例項。

0..1 表示可以有0個或者1個例項

0..* 表示對例項的數目沒有限制

1     表示只能有一個例項

1..* 表示至少有一個例項

關聯關係體現的是兩個類,或者類與介面之間的強依賴關係,這種關係很強烈,比依賴更強,不是偶然性的,也不是臨時性的,而是一種長期性,相對平等的關係,表現在程式碼層面,為被關聯的類B以類屬性的形式出現在類A中,也可能是關聯類A引用了被關聯類B的全域性變數。

在Java中,關聯關係是使用例項變數來實現的

 

聚合(aggregation)是關聯關係的特例,是強的關聯關係,聚合是整個與個體的關係,即has-a關係,此時整體和部分是可以分離的,他們具有各自的生命週期,部分可以屬於多個物件,也可以被多個物件共享;比如計算機和CPU,公司與員工的關係;在程式碼層面聚合與關聯是一致的,只能從語義上來區分。

聚合關係也是使用例項變數來實現的,在java語法上區分不出關聯和聚合,關聯關係中類出於一個層次,而聚合則明顯的在兩個不同的層次。

 

組合(compostion)也是關聯關係的一種特例,體現的是一種contain-a關係,比聚合更強,是一種強聚合關係。它同樣體現整體與部分的關係,但此時整體與部分是不可分的,整體生命週期的結束也意味著部分生命週期的結束,反之亦然。如大腦和人類。

體現在程式碼層面與關聯時一致的,只能從語義來區分。

組合與聚合幾乎完全相同,唯一區別就是對於組合,“部分”不同脫離“整體”單獨存在,其生命週期應該是一致的。

 

總結:

主要是關聯關係的細化需要注意強弱,由若到強分別是 依賴 < 關聯 < 聚合 < 組合

參考:

http://justsee.iteye.com/blog/808799