UML中的組合、聚合、關聯、繼承、實現、依賴

轉自:http://justsee.iteye.com/blog/808799設計

UML定義的關係主要有六種:依賴、類屬、關聯、實現、聚合和組合。對象

繼承

  • 指的是一個類(稱爲子類、子接口)繼承另外的一個類(稱爲父類、父接口)的功能,並能夠增長它本身的新功能的能力,繼承是類與類或者接口與接口之間最多見的關係;在Java中此類關係經過關鍵字extends明確標識,在設計時通常沒有爭議性;

實現

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

依賴

  • 能夠簡單的理解,就是一個類A使用到了另外一個類B,而這種使用關係是具備偶然性的、臨時性的、很是弱的,可是B類的變化會影響到A;好比某人要過河,須要借用一條船,此時人與船之間的關係就是依賴;表如今代碼層面,爲類B做爲參數被類A在某個method方法中使用、局部變量、靜態方法的調用;

關聯

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

聚合

  • 聚合是關聯關係的一種特例,他體現的是總體與部分、擁有的關係,即has-a的關係,此時總體與部分之間是可分離的,他們能夠具備各自的生命週期,部分能夠屬於多個總體對象,也能夠爲多個總體對象共享;好比計算機與CPU、公司與員工、學校和學生的關係等;表如今代碼層面,和關聯關係是一致的,只能從語義級別來區分;

組合

  • 組合也是關聯關係的一種特例,他體現的是一種contains-a的關係,這種關係比聚合更強,也稱爲強聚合;他一樣體現總體與部分間的關係,但此時總體與部分是不可分的,總體的生命週期結束也就意味着部分的生命週期結束;好比你和你的大腦、學校和學院;表如今代碼層面,和關聯關係是一致的,只能從語義級別來區分;

總結

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

相關文章
相關標籤/搜索