天天看點

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

最近在接觸UML的模組化語言,但是發現其中類之間的幾個關系不是很清楚,上網搜尋了一陣,發現此文章還是寫的不錯的,是以就轉載過來了,原文的位址為:http://blog.csdn.net/sfdev/article/details/3906243

這是一堂關于UML基礎知識的補習課;現在我們做項目時間都太緊了,基本上都沒有做過真正的class級别的詳細設計,更别提使用UML來實作規範模組化了;本篇主要就以前自己一直感覺很迷糊的幾種class之間的關系進行整理,讓我們在真正用UML進行比如類圖設計時能夠更加清晰明了;以下就分别介紹這幾種關系:

繼承

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

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

實作

指的是一個class類實作interface接口(可以是多個)的功能;實作是類與接口之間最常見的關系;在Java中此類關系通過關鍵字implements明确辨別,在設計時一般沒有争議性;

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

依賴

可以簡單的了解,就是一個類A使用到了另一個類B,而這種使用關系是具有偶然性的、、臨時性的、非常弱的,但是B類的變化會影響到A;比如某人要過河,需要借用一條船,此時人與船之間的關系就是依賴;表現在代碼層面,為類B作為參數被類A在某個method方法中使用;

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

關聯

他展現的是兩個類、或者類與接口之間語義級别的一種強依賴關系,比如我和我的朋友;這種關系比依賴更強、不存在依賴關系的偶然性、關系也不是臨時性的,一般是長期性的,而且雙方的關系一般是平等的、關聯可以是單向、雙向的;表現在代碼層面,為被關聯類B以類屬性的形式出現在關聯類A中,也可能是關聯類A引用了一個類型為被關聯類B的全局變量;

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

聚合

聚合是關聯關系的一種特例,他展現的是整體與部分、擁有的關系,即has-a的關系,此時整體與部分之間是可分離的,他們可以具有各自的生命周期,部分可以屬于多個整體對象,也可以為多個整體對象共享;比如計算機與CPU、公司與員工的關系等;表現在代碼層面,和關聯關系是一緻的,隻能從語義級别來區分;

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

組合

組合也是關聯關系的一種特例,他展現的是一種contains-a的關系,這種關系比聚合更強,也稱為強聚合;他同樣展現整體與部分間的關系,但此時整體與部分是不可分的,整體的生命周期結束也就意味着部分的生命周期結束;比如你和你的大腦;表現在代碼層面,和關聯關系是一緻的,隻能從語義級别來區分;

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

對于繼承、實作這兩種關系沒多少疑問,他們展現的是一種類與類、或者類與接口間的縱向關系;其他的四者關系則展現的是類與類、或者類與接口間的引用、橫向關系,是比較難區分的,有很多事物間的關系要想準備定位是很難的,前面也提到,這幾種關系都是語義級别的,是以從代碼層面并不能完全區分各種關系;但總的來說,後幾種關系所表現的強弱程度依次為:組合>聚合>關聯>依賴;

其實我不想對比這兩篇文章怎麼樣,但是給我的感覺就是我看了兩篇文章,我能學到很多東西,為了不留下遺憾,我決定還是轉載了,收為自己麾下,我們必須時刻記得,我們是站在巨人的肩膀上的,哈哈

一下原文轉自:http://blog.csdn.net/maybehelios/article/details/2038685

類之間的關系

1. 種類: Generalization(泛化),Dependency(依賴關系)、Association(關聯關系)、Aggregation(聚合關系)、Composition(合成關系)。

2.  其中Aggregation(聚合關系)、Composition(合成關系)屬于Association(關聯關系),是特殊的Association關聯關系。

3.  Generalization(泛化)表現為繼承或實作關系(is a)。具體形式為類與類之間的繼承關系,接口與接口之間的繼承關系,類對接口的實作關系。

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別
UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

4.  Association關聯關系表現為變量(has a )。類與類之間的聯接,它使一個類知道另一個類的屬性和方法。例如如果A依賴于B,則B展現為A的全局變量。關聯關系有雙向關聯和單向關聯。雙向關聯:兩個類都知道另一個類的公共屬性和操作。單向關聯:隻有一個類知道另外一個類的公共屬性和操作。大多數關聯應該是單向的,單向關系更容易建立和維護,有助于尋找可服用的類。

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別
UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

5.  Aggregation(聚合關系) 是關聯關系的一種,是強的關聯關系。聚合關系是整體和個體的關系。普通關聯關系的兩個類處于同一層次上,而聚合關系的兩個類處于不同的層次,一個是整體,一個是部分。同時,是一種弱的“擁有”關系。展現的是A對象可以包含B對象,但B對象不是A對象的組成部分。具體表現為,如果A由B聚合成,表現為A包含有B的全局對象,但是B對象可以不在A建立的時刻建立。

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

6.  Composition(組合關系)是關聯關系的一種,是比聚合關系強的關系。它要求普通的聚合關系中代表整體的對象負責代表部分的對象的生命周期。Composition(組合關系)是一種強的“擁有”關系,展現了嚴格的部分和整體的關系,部分和整體的生命周期一緻。如果A由B組成,表現為A包含有B的全局對象,并且B對象在A建立的時刻建立。

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

7.  Dependency(依賴關系)表現為函數中的參數(use a)。是類與類之間的連接配接,表示一個類依賴于另一個類的定義,其中一個類的變化将影響另外一個類。例如如果A依賴于B,則B展現為局部變量,方法的參數、或靜态方法的調用。

UML中類之間的幾種關系:繼承,實作,依賴,關聯,聚合,組合的差別

另:如果大家要收藏的話,請大家注明文章的出處,這個也是我轉的,人家花了心血總結出來的,我們不能随便的侵權啊。