1.1 定義
迪公尺特法則又叫最少知道原則:乙個物件應該對其他物件保持最少的了解。
迪公尺特法則,最早是在2023年由美國northeastern university的ian holland提出。通俗的來講,就是乙個類對自己依賴的類知道的越少越好。也就是說,對於被依賴的類來說,無論邏輯多麼複雜,都盡量地的將邏輯封裝在類的內部,對外除了提供的public方法,不對外洩漏任何資訊。迪公尺特法則還有乙個更簡單的定義:只與直接的朋友通訊。首先來解釋一下什麼是直接的朋友:每個物件都會與其他物件有耦合關係,只要兩個物件之間有耦合關係,我們就說這兩個物件之間是朋友關係。耦合的方式很多,依賴、關聯、組合、聚合等。其中,我們稱出現成員變數、方法引數、方法返回值中的類為直接的朋友,而出現在區域性變數中的類則不是直接的朋友。也就是說,陌生的類最好不要作為區域性變數的形式出現在類的內部。
1.2 uml類圖
1.3 設計背景
類與類之間的關係越密切,耦合度越大,當乙個類發生改變時,對另乙個類的影響也越大,比如說當乙個類方法裡面依賴了另乙個類,當這個依賴的類方法發生改變時,被依賴的類方法裡面就得重新修改為該依賴類的新方法,違背了設計原則的開閉原則。
舉乙個例子:有乙個集團公司,下屬單位有分公司和直屬部門,現在要求列印出所有下屬單位的員工id。先來看一下違反迪公尺特法則的設計。
/**
* @author tbb
* 總公司類
*/public
class
controllingcompany
public
void
setsumlist
(list
sumlist)
public
void
printemployeeid
(subcompany subcompany)
for(
int i =
0; i <
this
.sumlist.
size()
; i++)}
public
controllingcompany()
}
/**
* @author tbb
* 子公司類
*/public
class
subcompany
public
void
setsublist
(list
sublist)
public
subcompany()
}
/**
* @author tbb
* 總公司員工類
*/public
class
controllingcompanyemployee
public
void
setid
(string id)
}
/**
* @author tbb
* 子公司員工類
*/public
class
subcompanyemployee
public
void
setid
(string id)
}
public
class
test
}
現在這個設計的主要問題出在controllingcompany中,根據迪公尺特法則,只與直接的朋友發生通訊,而subcompanyemployee 類並不是controllingcompany類的直接朋友(以區域性變數出現的耦合不屬於直接朋友),從邏輯上講總公司只與他的分公司耦合就行了,與分公司的員工並沒有任何聯絡,這樣設計顯然是增加了不必要的耦合。按照迪公尺特法則,應該避免類**現這樣非直接朋友關係的耦合。
1.4 實現思路
為分公司增加了列印人員id的方法,總公司直接呼叫來列印,從而避免了與分公司的員工發生耦合。
迪公尺特法則的初衷是降低類之間的耦合,由於每個類都減少了不必要的依賴,因此的確可以降低耦合關係。但是凡事都有度,雖然可以避免與非直接的類通訊,但是要通訊,必然會通過乙個「中介」來發生聯絡,例如本例中,總公司就是通過分公司這個「中介」來與分公司的員工發生聯絡的。過分的使用迪公尺特原則,會產生大量這樣的中介和傳遞類,導致系統複雜度變大。所以在採用迪公尺特法則時要反覆權衡,既做到結構清晰,又要高內聚低耦合。
1.5 實現場景
修改後的**如下:
/**
* @author tbb
* 總公司類
*/public
class
controllingcompany
public
void
setsumlist
(list
sumlist)
public
void
printemployeeid
(subcompany subcompany)
}public
controllingcompany()
}
/**
* @author tbb
* 子公司類
*/public
class
subcompany
public
void
setsublist
(list
sublist)
public
subcompany()
public
void
printemployeeid()
}}
/**
* @author tbb
* 總公司員工類
*/public
class
controllingcompanyemployee
public
void
setid
(string id)
}
/**
* @author tbb
* 子公司員工類
*/public
class
subcompanyemployee
public
void
setid
(string id)
}
public
class
test
}
HeadFast設計模式之最少知識原則
最小知識原則就是在設計 的時候,注意減少物件之間的互動,只和滿足條件的物件進行互動。1 最小知識原則與德墨忒爾法則的關係?答 其實這兩個名詞指的是同乙個原則,但是我們更傾向於使用最小知識原則稱呼,原因有兩個,1 這個名字更直接。2 法則給人的感覺是強制,事實上沒有任何原則是法律。2 最小知識原則有哪...
設計原則 最少知識原則
定義 乙個物件應該對其他物件保持最少的了解。問題由來 類與類之間的關係越密切,耦合度越大,當乙個類發生改變時,對另乙個類的影響也越大。解決方案 盡量降低類與類之間的耦合。自從我們接觸程式設計開始,就知道了軟體程式設計的總的原則 低耦合,高內聚。無論是面向過程程式設計還是物件導向程式設計,只有使各個模...
設計原則 「最少知識」原則
1.定義 減少物件之間的互動,只留下關係密切的物件。最少知識原則也叫 law of demeter,迪公尺特法則,一句話概括是 不要和陌生人說話 2.目標 希望在我們的設計中,不要讓太多的類耦合在一起,免得修改系統中的一部分,會影響到其他部分。如果許多類之間相互依賴,那麼這個系統就會變成乙個易碎的系...