UML關系(泛化,實現,依賴,關聯(聚合,組合)
UML 中類與類, 類與接口, 接口與接口這間的關系有:泛化(generalization) 關系, 關聯(association)關系( 關聯, 聚合, 合成), 依賴(dependency)關系,實現(realization)關系.
泛化(generalization)關系
一個類(稱為子類、子接口)繼承另外的一個類(稱為父類、父接口)的功能,并可以增加它自己的新功能的能力,繼承是類與類或者接口與接口之間最常見的關系;在Java中此類關系通過關鍵字extends明確標識,在設計時一般沒有爭議性。
實現(realization)關系
一個class類實現interface接口(可以是多個)的功能;實現是類與接口之間最常見的關系;在Java中此類關系通過關鍵字implements明確標識,在設計時一般沒有爭議性;
依賴(dependency)關系
也是類與類之間的連接. 表示一個類依賴于另一個類的定義. 依賴關系總是單向的 。可以簡單的理解,就是一個類A使用到了另一個類B,而這種使用關系是具有偶然性的、、臨時性的、非常弱的,但是B類的變化會影響到A;比如某人要過河,需要借用一條船,此時人與船之間的關系就是依賴;表現在代碼層面,為類B作為參數被類A在某個method方法中使用。
在java 中. 依賴關系體現為: 局部變量, 方法中的參數, 和對靜態方法的調用.
關聯(association)關系
表示類與類之間的聯接, 它使一個類知道另一個類的屬性和方法.
關聯可以使用單箭頭表示單向關聯, 使用雙箭頭或不使用箭頭表示雙向關聯, 不建議使用雙向關聯. 關聯有兩個端點, 在每個端點可以有一個基數, 表示這個關聯的類可以有幾個實例.
常見的基數及含義:
0..1:0 或1 個實例.
0..*: 對實例的數目沒有限制.
1: 只能有一個實例.
1..*: 至少有一個實例.
他 體現的是兩個類、或者類與接口之間語義級別的一種強依賴關系,比如我和我的朋友;這種關系比依賴更強、不存在依賴關系的偶然性、關系也不是臨時性的,一般 是長期性的,而且雙方的關系一般是平等的,表現在代碼層面,為被關聯類B以類屬性的形式出現在關聯類A中,也可能是關聯類A引用了一個類型為被關聯類B的 全局變量;在java 語言中關聯關系是使用實例變量實現的.
聚合(aggregation)關系
關聯關系的一種特例, 是強的關聯關系. 聚合是整體和個體之間的關系,即has-a的關系,此時整體與部分之間是可分離的,他們可以具有各自的生命周期,部分可以屬于多個整體對象,也可以為多個整體對象共享;比如計算機與CPU、公司與員工的關系等;表現在代碼層面,和關聯關系是一致的,只能從語義級別來區分;
聚合關系也是使用實例變量實現的. 從java 語法上是分不出關聯和聚合的.
關聯關系中兩個類是處于相同的層次, 而聚合關系中兩不類是處于不平等的層次, 一個表示整體, 一個表示部分.
組合關系(composition)
也是關聯關系的一種特例,他體現的是一種contains-a的關系,這種關系比聚合更強,也稱為強聚合;他同樣體現整體與部分間的關系,但此時整體與部分是不可分的,整體的生命周期結束也就意味著部分的生命周期結束;比如你和你的大腦;合成關系不能共享. 。表現在代碼層面,和關聯關系是一致的,只能從語義級別來區分。
組合跟聚合幾乎相同,唯一的區別就是“部分”不能脫離“整體”單獨存在,就是說, “部分”的生命期不能比“整體”還要長。
總結
對于繼承、實現這兩種關系沒多少疑問,他們體現的是一種類與類、或者類與接口間的縱向關系;其他的四者關系則體現的是類與類、或者類與接口間的引用、橫 向關系,是比較難區分的,有很多事物間的關系要想準備定位是很難的,前面也提到,這幾種關系都是語義級別的,所以從代碼層面并不能完全區分各種關系;但總 的來說,后幾種關系所表現的強弱程度依次為:組合>聚合>關聯>依賴。
來自:http://justsee.iteye.com/blog/808799