UML類圖符號 各種關係說明以及舉例
UML中描述對象和類之間相互關係的方式包括:依賴(Dependency),關聯(Association),聚合(Aggregation),組合(Composition),泛化(Generalization),實現(Realization)等。
- 依賴(Dependency):元素A的變化會影響元素B,但反之不成立,那麼B和A的關係是依賴關係,B依賴A;類屬關係和實現關係在語義上講也是依賴關係,但由於其有更特殊的用途,所以被單獨描述。uml中用帶箭頭的虛線表示Dependency關係,箭頭指向被依賴元素。
- 泛化(Generalization):通常所說的繼承(特殊個體 is kind of 一般個體)關係,不必多解釋了。uml中用帶空心箭頭的實線線表示Generalization關係,箭頭指向一般個體。
- 實現(Realize):元素A定義一個約定,元素B實現這個約定,則B和A的關係是Realize,B realize A。這個關係最常用於接口。uml中用空心箭頭和虛線表示Realize關係,箭頭指向定義約定的元素。
- 關聯(Association):元素間的結構化關係,是一種弱關係,被關聯的元素間通常可以被獨立的考慮。uml中用實線表示Association關係,箭頭指向被依賴元素。
- 聚合(Aggregation):關聯關係的一種特例,表示部分和整體(整體 has a 部分)的關係。uml中用帶空心菱形頭的實線表示Aggregation關係,菱形頭指向整體。
- 組合(Composition):組合是聚合關係的變種,表示元素間更強的組合關係。如果是組合關係,如果整體被破壞則個體一定會被破壞,而聚合的個體則可能是被多個整體所共享的,不一定會隨着某個整體的破壞而被破壞。uml中用帶實心菱形頭的實線表示Composition關係,菱形頭指向整體。
其中依賴(Dependency)的關係最弱,而關聯(Association),聚合(Aggregation),組合(Composition)表示的關係依次增強。換言之關聯,聚合,組合都是依賴關係的一種,聚合是表明對象之間的整體與部分關係的關聯,而組合是表明整體與部分之間有相同生命週期關係的聚合。
而關聯與依賴的關係用一句話概括下來就是,依賴描述了對象之間的調用關係,而關聯描述了對象之間的結構關係。
後面的例子將針對某個具體目的來獨立地展示各種關係。雖然語法無誤,但這些例子可進一步精煉,在它們的有效範圍內包括更多的語義。
1.1.1 依賴(Dependency):虛線箭頭表示
1、依賴關係也是類與類之間的聯結
2、依賴總是單向的。(#add 注意,要避免雙向依賴。一般來說,不應該存在雙向依賴。)
3、依賴關係在 Java 或 C++ 語言中體現爲局部變量、方法的參數或者對靜態方法的調用。
class Person { void buy(Car car) { ... } }
|
表示方法:虛線加箭頭
特點:當類與類之間有使用關係時就屬於依賴關係,不同於關聯關係,依賴不具有“擁有關係”,而是一種“相識關係”,只在某個特定地方(比如某個方法體內)纔有關係
1.1.2 關聯(Association):實線箭頭表示
1、關聯關係是類與類之間的聯結,它使一個類知道另一個類的屬性和方法。
2、關聯可以是雙向的,也可以是單向的(#add還有自身關聯)。雙向的關聯可以有兩個箭頭或者沒有箭頭,單向的關聯有一個箭頭。
3、在 Java 或 c++ 中,關聯關係是通過使用成員變量來實現的。
class 徒弟 { };
class 唐僧 { protected: list<徒弟> tdlist; }; |
表示方法:實線箭頭
特徵:表示類與類或類與接口之間的依賴關係,表現爲“擁有關係”;具體到代碼可以用實例變量來表示。
1.1.3 聚合(Aggregation):帶空心菱形頭表示
1、聚合關係是關聯關係的一種,是強的關聯關係。
2、聚合是整體和部分之間的關係,例如汽車由引擎、輪胎以及其它零件組成。
3、聚合關係也是通過成員變量來實現的。但是,關聯關係所涉及的兩個類處在同一個層次上,而聚合關係中,兩個類處於不同的層次上,一個代表整體,一個代表部分。
4、關聯與聚合僅僅從 Java 或 C++ 語法上是無法分辨的,必須考察所涉及的類之間的邏輯關係。
class 引擎 { };
class 輪胎 { };
class 汽車 { protected:引擎 engine; protected:輪胎 tyre[4]; };
|
表示方法:空心菱形頭
特徵:屬於是關聯的特殊情況,體現部分-整體關係,是一種弱擁有關係;整體和部分可以有不一樣的生命週期;是一種弱關聯;
1.1.4 合成(Composition):帶實心菱形頭的實線表示
1、合成關係是關聯關係的一種,是比聚合關係還要強的關係。
2、它要求普通的聚合關係中代表整體的對象負責代表部分的對象的生命週期。
class 肢 { };
class 人 { protected: 肢 limb[4]; }; |
一般是實心菱形加實線箭頭表示
特徵:屬於是關聯的特殊情況,也體現了體現部分-整體關係,是一種強“擁有關係”;整體與部分有相同的生命週期,是一種強關聯;
一般化關係(泛化和實現):表示類與類之間的繼承關係,接口與接口之間的繼承關係,或類對接口的實現關係。一般化關係是子類指向父類的,或從實現接口的類指向被實現的接口,與繼承或實現的方向相反。如下圖所示:
圖:一般化關係
1.1.5 泛化(Generalization):
帶空心箭頭的實線線表示
泛化(圖H)表示一個更泛化的元素和一個更具體的元素之間的關係。泛化是用於對繼承進行建模的UML元素。在Java中,用extends關鍵字來直接表示這種關係。
泛化關係表示類與類之間的繼承關係,接口與接口之間的繼承關係。圖H
1.1.6 實現(Realization):空心箭頭和虛線表示
實例(圖I)關係指定兩個實體之間的一個合同。換言之,一個實體定義一個合同,而另一個實體保證履行該合同。對Java應用程序進行建模時,實現關係可直接用implements關鍵字來表示。
圖I