大魚

          UML 繼承、實現、依賴、關聯、聚合、組合的聯系與區別

          這是一堂關于UML基礎知識的補習課;現在我們做項目時間都太緊了,基本上都沒有做過真正的class級別的詳細設計,更別提使用UML來實現規范建模了;本篇主要就以前自己一直感覺很迷糊的幾種class之間的關系進行整理,讓我們在真正用UML進行比如類圖設計時能夠更加清晰明了;以下就分別介紹這幾種關系:

          繼承

          指的是一個類(稱為子類、子接口)繼承另外的一個類(稱為父類、父接口)的功能,并可以增加它自己的新功能的能力,繼承是類與類或者接口與接口之間最常見的關系;在Java中此類關系通過關鍵字extends明確標識,在設計時一般沒有爭議性;

          UML 繼承、實現、依賴、關聯、聚合、組合的聯系與區別 - xiaotot - 享受編碼

          實現

          指的是一個class類實現interface接口(可以是多個)的功能;實現是類與接口之間最常見的關系;在Java中此類關系通過關鍵字implements明確標識,在設計時一般沒有爭議性;

          UML 繼承、實現、依賴、關聯、聚合、組合的聯系與區別 - xiaotot - 享受編碼

          依賴

          可以簡單的理解,就是一個類A使用到了另一個類B,而這種使用關系是具有偶然性的、、臨時性的、非常弱的,但是B類的變化會影響到A;比如某人要過河,需要借用一條船,此時人與船之間的關系就是依賴;表現在代碼層面,為類B作為參數被類A在某個method方法中使用;

          UML 繼承、實現、依賴、關聯、聚合、組合的聯系與區別 - xiaotot - 享受編碼

          關聯

          他體現的是兩個類、或者類與接口之間語義級別的一種強依賴關系,比如我和我的朋友;這種關系比依賴更強、不存在依賴關系的偶然性、關系也不是臨時性的,一般是長期性的,而且雙方的關系一般是平等的、關聯可以是單向、雙向的;表現在代碼層面,為被關聯類B以類屬性的形式出現在關聯類A中,也可能是關聯類A引用了一個類型為被關聯類B的全局變量;

          UML 繼承、實現、依賴、關聯、聚合、組合的聯系與區別 - xiaotot - 享受編碼

          聚合

          聚合是關聯關系的一種特例,他體現的是整體與部分、擁有的關系,即has-a的關系,此時整體與部分之間是可分離的,他們可以具有各自的生命周期,部分可以屬于多個整體對象,也可以為多個整體對象共享;比如計算機與CPU、公司與員工的關系等;表現在代碼層面,和關聯關系是一致的,只能從語義級別來區分;

          UML 繼承、實現、依賴、關聯、聚合、組合的聯系與區別 - xiaotot - 享受編碼

          組合

          組合也是關聯關系的一種特例,他體現的是一種contains-a的關系,這種關系比聚合更強,也稱為強聚合;他同樣體現整體與部分間的關系,但此時整體與部分是不可分的,整體的生命周期結束也就意味著部分的生命周期結束;比如你和你的大腦;表現在代碼層面,和關聯關系是一致的,只能從語義級別來區分;

          UML 繼承、實現、依賴、關聯、聚合、組合的聯系與區別 - xiaotot - 享受編碼

          對于繼承、實現這兩種關系沒多少疑問,他們體現的是一種類與類、或者類與接口間的縱向關系;其他的四者關系則體現的是類與類、或者類與接口間的引用、橫向關系,是比較難區分的,有很多事物間的關系要想準備定位是很難的,前面也提到,這幾種關系都是語義級別的,所以從代碼層面并不能完全區分各種關系;但總的來說,后幾種關系所表現的強弱程度依次為:組合>聚合>關聯>依賴

          posted on 2011-10-06 23:15 大魚 閱讀(314) 評論(0)  編輯  收藏 所屬分類: 軟件工程

          主站蜘蛛池模板: 前郭尔| 阿荣旗| 延津县| 巴马| 石阡县| 南平市| 吴旗县| 无极县| 阜城县| 金溪县| 南溪县| 万盛区| 深圳市| 游戏| 伊宁县| 桃园县| 通辽市| 宁蒗| 和平区| 林周县| 延津县| 敦化市| 行唐县| 宣威市| 辽中县| 准格尔旗| 安平县| 西林县| 东乌珠穆沁旗| 新龙县| 康平县| 峨眉山市| 五台县| 咸宁市| 习水县| 同德县| 迁安市| 宁武县| 镶黄旗| 满城县| 泰兴市|