此文為轉(zhuǎn)載文章:http://zjzkiss.cnblogs.com/ 世界是普遍聯(lián)系的,因此程序世界中的類,也不可能是孤立的。UML為我們定義了它們之間的關(guān)系,就是:依賴、關(guān)聯(lián)、聚合、組合還有泛化。
泛化關(guān)系比較好理解,就是表示類之間的繼承關(guān)系。容易混淆的是依賴、關(guān)聯(lián)、聚合和組合的關(guān)系。這里做一些甄別:
1、 依賴和關(guān)聯(lián)的顛倒顛
在網(wǎng)上查找了一下依賴和關(guān)聯(lián)的區(qū)別,有說(shuō)“關(guān)聯(lián)本身即是一種依賴”,亦有說(shuō)“依賴是一種弱關(guān)聯(lián)”,其實(shí)說(shuō)來(lái)說(shuō)去是一檔子事。依賴和關(guān)聯(lián)都是說(shuō)一個(gè)類用到了另一個(gè)類。其區(qū)別在于一個(gè)是使用,一個(gè)是擁有。
依賴:具有某種偶然性。比如說(shuō)我要過(guò)河,沒(méi)有橋怎么辦,我就去借來(lái)一條小船渡過(guò)去。我與小船的關(guān)系僅僅是使用(借用)的關(guān)系。表現(xiàn)在代碼上,為依賴的類的某個(gè)方法以被依賴的類作為其參數(shù)?;蛘呤莄lass A 的某個(gè)方法創(chuàng)造了 class B 的實(shí)例抑或?qū)lass B的靜態(tài)方法的調(diào)用。如果A依賴于B,那意味著B的變化可能要求A也發(fā)生變化;
這是uml圖表示的依賴關(guān)系: 代碼表現(xiàn):
關(guān)聯(lián):有名的客戶和訂單的關(guān)系以及公司和員工的關(guān)系,都是關(guān)聯(lián)關(guān)系。還有就是我和我的單車的例子,他們都是一種“擁有”的關(guān)系。表現(xiàn)在代碼上,就是一個(gè)類包含另一個(gè)類的實(shí)例,通常表現(xiàn)為被關(guān)聯(lián)類以類屬性的形式出現(xiàn)在關(guān)聯(lián)類的類定義中,也可以表現(xiàn)為關(guān)聯(lián)類引用了一個(gè)類型為被關(guān)聯(lián)類的全局變量。關(guān)聯(lián)可以使單向的,也可以使雙向的。
從網(wǎng)上找到的公司和員工的UML圖和代碼 :
公司和員工的關(guān)聯(lián)關(guān)系
可見依賴于與關(guān)聯(lián)亦有動(dòng)靜之別,關(guān)聯(lián)的類“靜態(tài)”地引用了被關(guān)聯(lián)類的實(shí)例變量,而依賴的偶然性也正說(shuō)明了它的動(dòng)態(tài)性。
2、 聚合與組合同出而異體
聚合與組合其實(shí)都是關(guān)聯(lián)的特例,都是整體和部分的關(guān)系。他們的區(qū)別在于聚合的兩個(gè)對(duì)象之間是可分離的,他們具有各自的生命周期。而組合往往表現(xiàn)為一種唇齒相依的關(guān)系。
聚合:一種容納或曰包含的關(guān)系,如同機(jī)場(chǎng)和飛機(jī),汽車和輪胎的關(guān)系。其實(shí)仔細(xì)想想,前面的公司和員工的關(guān)系也有聚合的味道在里面。
組合:也可稱之為強(qiáng)聚合,整體和部分是不可分的,整體的生命周期結(jié)束時(shí)也就是部分的生命周期到頭時(shí)。很有名的就是桌子和桌子腿的關(guān)系。
聚合的UML圖:
組合的UML圖:
然而,聚合與組合的代碼表現(xiàn)形式是一樣的,都可以表現(xiàn)為以下的形式,它們僅僅具有語(yǔ)義上的區(qū)別。
網(wǎng)上找到的電腦和CPU的關(guān)系的代碼表現(xiàn):