專家講解 UML關(guān)聯(lián)、依賴、聚集等關(guān)系的異同
本節(jié)向大家介紹一下UML中UML關(guān)聯(lián)、依賴、聚集等關(guān)系的異同,相信通過本節(jié)的介紹你對UML中UML關(guān)聯(lián)、依賴、聚集等關(guān)系的特點(diǎn)和作用有全面的認(rèn)識。下面是具體介紹。
UML中UML關(guān)聯(lián)、依賴、聚集等關(guān)系的異同
1.關(guān)聯(lián):連接模型元素及鏈接實(shí)例,用一條實(shí)線來表示;
2.依賴:表示一個元素以某種方式依賴于另一個元素,用一條虛線加箭頭來表示;
3.聚集:表示整體與部分的關(guān)系,用一條實(shí)線加空心菱形來表示;
4.組成:表示整體與部分的有一關(guān)系,用一條實(shí)線加實(shí)心菱形來表示;
5.泛化(繼承):表示一般與特殊的關(guān)系,用一條實(shí)線加空心箭頭來表示;
6.實(shí)現(xiàn):表示類與接口的關(guān)系,用一條虛線加空心箭頭來表示;
UML關(guān)聯(lián),依賴,聚集的異同:(《Java面向?qū)ο缶幊獭芬粫髡撸簩O衛(wèi)琴來源:www.javathinker.org)
在建立對象模型時,很容易把依賴、關(guān)聯(lián)和聚集關(guān)系混淆。當(dāng)對象A和對象B之間存在依賴、關(guān)聯(lián)或聚集關(guān)系時,對象A都有可能調(diào)用對象B的方法,這是三種關(guān)系之間的相同之處,除此之外,它們有著不同的特征。
1.依賴關(guān)系的特征
對于兩個相對獨(dú)立的系統(tǒng),當(dāng)一個系統(tǒng)負(fù)責(zé)構(gòu)造另一個系統(tǒng)的實(shí)例,或者依賴另一個系統(tǒng)的服務(wù)時,這兩個系統(tǒng)之間主要體現(xiàn)為依賴關(guān)系,例如生產(chǎn)零件的機(jī)器和零件,機(jī)器負(fù)責(zé)構(gòu)造零件對象。再例如充電電池和充電器,充電電池通過充電器來充電。再例如自行車Bicycle和打氣筒Pump,自行車通過打氣筒來充氣。圖1-39為Bicycle類與Pump類的類框圖。
圖1-39Bicycle類與Pump類的依賴關(guān)系
Bicycle類和Pump類之間是依賴關(guān)系,在Bicycle類中無需定義Pump類型的變量。Bicycle類的定義如下:
publicclassBicycle{
/**給輪胎充氣*/
publicvoidexpand(Pumppump){
pump.blow();
}
}
在現(xiàn)時生活中,通常不會為某一輛自行車配備專門的打氣筒,而是在需要充氣的時候,從附近某個修車棚里借個打氣筒打氣。在程序代碼中,表現(xiàn)為Bicycle類的expand()方法有個Pump類型的參數(shù)。以下程序代碼表示某輛自行車先后到兩個修車棚里充氣:
myBicycle.expand(pumpFromRepairShed1);//到第一個修車棚里充氣
myBicycle.expand(pumpFromRepairShed2);//若干天后,到第二個修車棚里充氣
2.UML關(guān)聯(lián)關(guān)系的特征
對于兩個相對獨(dú)立的系統(tǒng),當(dāng)一個系統(tǒng)的實(shí)例與另一個系統(tǒng)的一些特定實(shí)例存在固定的對應(yīng)關(guān)系時,這兩個系統(tǒng)之間為關(guān)聯(lián)關(guān)系。例如客戶和訂單,每個訂單對應(yīng)特定的客戶,每個客戶對應(yīng)一些特定的訂單;再例如公司和員工,每個公司對應(yīng)一些特定的員工,每個員工對應(yīng)一特定的公司;再例如自行車和主人,每輛自行車屬于特定的主人,每個主人有特定的自行車,圖1-40顯示了主人和自行車的關(guān)聯(lián)關(guān)系。而充電電池和充電器之間就不存在固定的對應(yīng)關(guān)系,同樣自行車和打氣筒之間也不存在固定的對應(yīng)關(guān)系。
圖1-40主人和自行車的關(guān)聯(lián)關(guān)系
Person類與Bicycle類之間存在關(guān)聯(lián)關(guān)系,這意味著在Person類中需要定義一個Bicycle類型的成員變量。以下是Person類的定義:
publicclassPerson{
privateBicyclebicycle;//主人的自行車
publicBicyclegetBicycle(){
returnbicycle;
}
publicvoidsetBicycle(Bicyclebicycle){
this.bicycle=bicycle;
}
/**騎自行車去上班*/
publicvoidgoToWork(){
bicycle.run();
}
}
在現(xiàn)時生活中,當(dāng)你騎自行車去上班時,只要從家里推出自己的自行車就能上路了,不象給自行車打氣那樣,在需要打氣時,還要四處去找修車棚。因此,在Person類的goToWork()方法中,調(diào)用自身的bicycle對象的run()方法。假如goToWork()方法采用以下的定義方式:
/**騎自行車去上班*/
publicvoidgoToWork(Bicyclebicycle){
bicycle.run();
}
那就好比去上班前,還要先四處去借一輛自行車,然后才能去上班。
3.聚集關(guān)系的特征
學(xué)習(xí)了UML關(guān)聯(lián)關(guān)系的特征,那么聚集關(guān)系有什么特征呢。當(dāng)系統(tǒng)A被加入到系統(tǒng)B中,成為系統(tǒng)B的組成部分時,系統(tǒng)B和系統(tǒng)A之間為聚集關(guān)系。例如自行車和它的響鈴、龍頭、輪胎、鋼圈以及剎車裝置就是聚集關(guān)系,因?yàn)轫戔徥亲孕熊嚨慕M成部分。而人和自行車不是聚集關(guān)系,因?yàn)槿瞬皇怯勺孕熊嚱M成的,如果一定要研究人的組成,那么他應(yīng)該由頭、軀干和四肢等組成。由此可見,可以根據(jù)語義來區(qū)分關(guān)聯(lián)關(guān)系和聚集關(guān)系。
聚集關(guān)系和關(guān)聯(lián)關(guān)系的區(qū)別還表現(xiàn)在以下方面:
(1)對于具有關(guān)聯(lián)關(guān)系的兩個對象,多數(shù)情況下,兩者有獨(dú)立的生命周期。比如自行車和他的主人,當(dāng)自行車不存在了,它的主人依然存在;反之亦然。但在個別情況下,一方會制約另一方的生命周期。比如客戶和訂單,當(dāng)客戶不存在,它的訂單也就失去存在的意義。
(2)對于具有聚集關(guān)系(尤其是強(qiáng)聚集關(guān)系)的兩個對象,整體對象會制約它的組成對象的生命周期。部分類的對象不能單獨(dú)存在,它的生命周期依賴于整體類的對象的生命周期,當(dāng)整體消失,部分也就隨之消失。比如小王的自行車被偷了,那么自行車的所有組件也不存在了,除非小王事先碰巧把一些可拆卸的組件(比如車鈴和坐墊)拆了下來。
不過,在用程序代碼來表示關(guān)聯(lián)關(guān)系和聚集關(guān)系時,兩者比較相似。圖1-41為自行車Bicycle與響鈴Bell的聚集關(guān)系。
圖1-41自行車和響鈴的聚集關(guān)系
以下例程1-6是Bicycle類的源程序。
例程1-6Bicycle.java
publicclassBicycle{
privateBellbell;
publicBellgetBell(){
returnbell;
}
publicvoidsetBell(Bellbell){
this.bell=bell;
}
/**發(fā)出鈴聲*/
publicvoidalert(){
bell.ring();
}
}
在Bicycle類中定義了Bell類型的成員變量,Bicycle類利用自身的bell成員變量來發(fā)出鈴聲,這和在Person類中定義了Bicycle類型的成員變量,Person類利用自身的bicycle成員變量去上班很相似。
4。組成關(guān)系的特征
組成關(guān)系是一種兩個類之間的關(guān)系,其中整體類由部分類組成,部分類需要整體類才能存在,這種關(guān)系意味著銷毀整體類將會同時銷毀部分類。本節(jié)關(guān)于UML中UML關(guān)聯(lián)、依賴、聚集等關(guān)系的異同就簡單介紹到這里。
【編輯推薦】
- UML關(guān)聯(lián)符號用法剖析
- 幾種UML關(guān)聯(lián)關(guān)系的區(qū)別詳解
- 實(shí)例講解UML對象圖使用
- 軟件設(shè)計(jì)過程中面向?qū)ο骍ML技術(shù)如何使用
- UML建?;A(chǔ)教程