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