選自《JAVA語言程序設計-基礎篇(原書第8版)》
定義:一個對象可以包含另一個對象。這兩個對象之間的關係稱為組合(composition)。
組合實際上是聚集關係的一種特殊形式。聚集模擬了具有(has-a)關係,表示兩個對象之間的歸屬關係。歸屬關係中的所有者對象稱為聚集對象(aggregation object),而它的類稱為聚集類(aggregating class)。歸屬關係中的從屬對象稱為被聚集類(aggregated object),而它的類被稱為被聚集類(aggregated class)。
一個對象可以被幾個其他聚集對象所擁有。如果一個對像只歸屬於一個聚集對象,那麼它和聚集對象之間的關係就稱為組合(composition)。例如:“一個學生有一個名字”就是組合關係,“一個學生有一個地址”就是聚集關係,因為一個地址可以被幾個學生所共享。
UML中,實心菱形表示組合關係,空心菱形表示聚集關係。如圖:
聚集關係通常被表示為聚集類中的一個數據域,如圖:
聚集還可以存在於同一類的多個對象之間。例如:一個人可能有一個管理者或者多個管理者。一個管理者可用變量表示,多個則可使用數組,如圖:
到這裡,基本上聚集和組合的關係就不言自明了。
以上這篇深入理解JAVA中的聚集和組合的區別與聯繫就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。