UML中描述對象和類之間相互關系的方式包括:依賴,關聯,聚合,組合,泛化,實現等。
?
表示關系的強弱:組合>聚合>關聯>依賴
相互間關系
聚合是表明對象之間的整體與部分關系的關聯,而組合是表明整體與部分之間有相同生命周期關系的聚合。而關聯與依賴的關系是,依賴描述了對象之間的調用關系,而關聯描述了對象之間的結構關系。
依賴(Dependency):虛線箭頭表示
1、依賴關系也是類與類之間的聯結
2、依賴總是單向的。(#add 注意,要避免雙向依賴。一般來說,不應該存在雙向依賴。)
3、依賴關系在?Java?或 C++ 語言中體現為局部變量、方法的參數或者對靜態方法的調用。
?
- class?Person{??
- ????void?buy(Car?car){};??
- }??
虛線加箭頭
?
?
關聯(Association):實線箭頭表示
關聯(Association):元素間的結構化關系,是一種弱關系,被關聯的元素間通常可以被獨立的考慮。uml中用實線表示Association關系,箭頭指向被依賴元素。
1、關聯關系是類與類之間的聯結,它使一個類知道另一個類的屬性和方法。
2、關聯可以是雙向的,也可以是單向的(#add還有自身關聯)。雙向的關聯可以有兩個箭頭或者沒有箭頭,單向的關聯有一個箭頭。
3、在 Java 或 c++ 中,關聯關系是通過使用成員變量來實現的。
- class?徒弟{????
- }??
- class?唐僧{??
- ?????private?List<徒弟>?tdlist;??
- }??
?
?
?
聚合(Aggregation):帶空心菱形頭表示
聚合(Aggregation):關聯關系的一種特例,表示部分和整體(整體 has a 部分)的關系。uml中用帶空心菱形頭的實線表示,菱形頭指向整體。
1、聚合關系是關聯關系的一種,是強的關聯關系。
2、聚合是整體和部分之間的關系,例如汽車由引擎、輪胎以及其它零件組成。
3、聚合關系也是通過成員變量來實現的。但是,關聯關系所涉及的兩個類處在同一個層次上,而聚合關系中,兩個類處于不同的層次上,一個代表整體,一個代表部分。
4、關聯與聚合僅僅從 Java 或 C++ 語法上是無法分辨的,必須考察所涉及的類之間的邏輯關系。
- class?引擎{??
- ??
- }??
- class?輪胎{??
- ??
- }??
- class?汽車{??
- ???????private?引擎?engine;??
- ???????private?輪胎?tyre[4];??
- }??
?
?
組合(Composition):帶實心菱形頭的實線表示
組合(Composition):組合是聚合關系的變種,表示元素間更強的組合關系。如果是組合關系,如果整體被破壞則個體一定會被破壞,而聚合的個體則可能是被多個整體所共享的,不一定會隨著某個整體的破壞而被破壞。uml中用帶實心菱形頭的實線表示Composition關系,菱形頭指向整體。
?
1、合成關系是關聯關系的一種,是比聚合關系還要強的關系。
2、它要求普通的聚合關系中代表整體的對象負責代表部分的對象的生命周期。
?
- class?肢{??
- }??
- class?人{??
- ?????private?肢???limb[4];??
- }??
?
?
?
一般化關系(泛化和實現):
表示類與類之間的繼承關系,接口與接口之間的繼承關系,或類對接口的實現關系。一般化關系是子類指向父類的,或從實現接口的類指向被實現的接口,與繼承或實現的方向相反。如下圖所示:
一般化關系
?
?
?泛化(Generalization):
泛化(Generalization):通常所說的繼承(特殊個體 is kind of 一般個體)關系,不必多解釋了。uml中用帶空心箭頭的實線表示,箭頭指向一般個體。
?
帶空心箭頭的實線線表示
泛化表示一個更泛化的元素和一個更具體的元素之間的關系。泛化是用于對繼承進行建模的UML元素。在Java中,用extends關鍵字來直接表示這種關系。
泛化關系表示類與類之間的繼承關系,接口與接口之間的繼承關系。
?
實現(Realization):空心箭頭和虛線表示
實現(Realize):元素A定義一個約定,元素B實現這個約定,則B和A的關系是Realize,B realize A。這個關系最常用于接口。uml中用空心箭頭和虛線表示,箭頭指向定義約定的元素。
實現關系指定兩個實體之間的一個合同。換言之,一個實體定義一個合同,而另一個實體保證履行該合同。對Java應用程序進行建模時,實現關系可直接用implements關鍵字來表示。
?