OOP面向對象關系剖析
一、繼承關系
繼承指的是一個類(稱為子類、子接口)繼承另外的一個類(父類、父接口)的功能,并可以增加它自己的新功能的能力。在java中繼承關系通過關鍵字extends明確標識,在設計時一般沒有爭議性。類圖設計中,繼承用一條帶空心三角箭頭的實線表示,從子類指向父類,或者子接口指向父接口。
二、實現關系
實現指的是一個Class類實現interface接口(可以是多個)的功能,實現是類與接口之間最常見的關系。在java中實現關系通過implements明確標識,在設計時一般沒有爭議性。在UML類圖設計中,實現用一條帶空心三角箭頭的虛線表示,從類指向實現的接口。
三、依賴關系
依賴就是一個類A使用到了另一個類B,而這種使用關系是具有偶然性、臨時性、非常弱的,但是類B的變化會影響到類A。比如某人要過河,需要借用一條船,此時人與船之間的關系就是依賴。表現在代碼層面為,類B作為參數被類A在某個method方法中使用。在UML類圖設計中,依賴關系用由類A指向類B的帶箭頭虛線表示。
四、關聯關系
關聯體現的是兩個類之間語義級別的強依賴關系,比如我和我的朋友,這種關系比依賴更強、不存在依賴關系的偶然性、關系也不是臨時性的,一般是長期性的,而且雙方的關系一般是平等的。關聯可以是單向、雙向的。表現在代碼層面為,被關聯類B以類的屬性的形式出現在關聯類A中,也可能是關聯類A引用了一個類型為被關聯類B的全局變量。在UML類圖設計中,關聯關系用由關聯類A指向被關聯類B的帶箭頭實線表示,在關聯的兩端可以標注關聯雙方的角色和多重性標記。
五、聚合關系
聚合是關聯關系的一種特例,它體現的是整體與部分的關系,即has-a的關系。此時整體與部分之間是可分離的,它們可以具有各自的生命周期,部分可以屬于多個整體對象,也可以為多個整體對象共享。比如計算機與CPU、公司與員工的關系等,比如一個航母編隊包括航空母艦、驅逐護衛艦、艦載飛機及核動力攻擊潛艇等。表現在代碼層面,和關聯關系是一致的,只能從語義級別來區分。在UML類圖設計中,聚合關系以空心菱形加實線箭頭表示。
六、組合關系
組合也是關聯關系的一種特例,它體現的是contains-a的關系,這種關系比聚合更強,也成為強聚合。它同樣體現整體與部分間的關系,但此時整體與部分是不可分的,整體的生命周期結束也就意味著部分的生命周期結束,比如人和人的大腦。表現在代碼層面,和關聯關系是一致的,只能從語義級別來區分。在UML類圖設計中,組合關系以實心菱形加實線箭頭表示。
總結:
對于繼承、實現這兩種關系沒多少疑問,它們體現的是類和類、類與接口之間的縱向關系。其他的四種關系體現的是類與類、或者類與接口之間的引用、橫向關系,是比較難區分的,有很多事物間的關系要想準確定位是很難的。前面也提到,這四種關系都是語義級別的,所以從代碼層面并不能完全區分各種關系,但總的來說,后幾種關系所表現的強弱程度依次為:組合>聚合>關聯>依賴。
UML
版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。