在java以及其他的面向對象設計模式中,類與類之間主要有6種關係,他們分別是:依賴、關聯、聚合、組合、繼承、實現。他們的耦合度依次增強。
依賴關係的定義爲:對於兩個相對獨立的對象,當一個對象負責構造另一個對象的實例,或者依賴另一個對象的服務時,這兩個對象之間主要體現爲依賴關係。定義比較晦澀難懂,但在java中的表現還是比較直觀的:類A當中使用了類B,其中類B是作爲類A的方法參數、方法中的局部變量、或者靜態方法調用。類上面的圖例中:People類依賴於Book類和Food類,Book類和Food類是作爲類中方法的參數形式出現在People類中的。
代碼樣例:
public class People{
//Book作爲read方法的形參
public void read(Book book){
System.out.println(“讀的書是”+book.getName());
}
}
對於兩個相對獨立的對象,當一個對象的實例與另一個對象的一些特定實例存在固定的對應關係時,這兩個對象之間爲關聯關係。關聯關係分爲單向關聯和雙向關聯。在java中,單向關聯表現爲:類A當中使用了類B,其中類B是作爲類A的成員變量。雙向關聯表現爲:類A當中使用了類B作爲成員變量;同時類B中也使用了類A作爲成員變量。
代碼樣例:
public class Son{
//關聯關係中作爲成員變量的類一般會在類中賦值
Father father = new Father();
public void getGift(){
System.out.println(“從”+father.getName()+”獲得禮物”);
}
}
public class Father{
Son son = new Son();
public void giveGift(){
System.out.println(“送給”+son.getName()+“禮物”);
}
}
聚合關係是關聯關係的一種,耦合度強於關聯,他們的代碼表現是相同的,僅僅是在語義上有所區別:關聯關係的對象間是相互獨立的,而聚合關係的對象之間存在着包容關係,他們之間是“整體-個體”的相互關係。
代碼樣例:
public class People{
Car car;
House house;
//聚合關係中作爲成員變量的類一般使用set方法賦值
public void setCar(Car car){
This.car = car;
}
public void setHouse(House house){
This.house = house;
}
public void driver(){
System.out.println(“車的型號:”+car.getType());
}
public void sleep(){
System.out.println(“我在房子裏睡覺:”+house.getAddress());
}
}
相比於聚合,組合是一種耦合度更強的關聯關係。存在組合關係的類表示“整體-部分”的關聯關係,“整體”負責“部分”的生命週期,他們之間是共生共死的;並且“部分”單獨存在時沒有任何意義。在下圖的例子中,People與Soul、Body之間是組合關係,當人的生命週期開始時,必須同時有靈魂和肉體;當人的生命週期結束時,靈魂肉體隨之消亡;無論是靈魂還是肉體,都不能單獨存在,他們必須作爲人的組成部分存在。
Public class People{
Soul soul;
Body body;
//組合關係中的成員變量一般會在構造方法中賦值
Public People(Soul soul, Body body){
This.soul = soul;
This.body = body;
}
Public void study(){
System.out.println(“學習要用靈魂”+soul.getName());
}
Public void eat(){
System.out.println(“吃飯用身體:”+body.getName());
}
}
繼承表示類與類(或者接口與接口)之間的父子關係。在java中,用關鍵字extends表示繼承關係。UML圖例中,繼承關係用實線+空心箭頭表示,箭頭指向父類。
表示一個類實現一個或多個接口的方法。接口定義好操作的集合,由實現類去完成接口的具體操作。在java中使用implements表示。UML圖例中,實現關係用虛線+空心箭頭表示,箭頭指向接口。
在java中繼承使用extends關鍵字,實現使用implements關鍵字,很直觀。就不代碼演示了。