基本介紹
1)一個對象應該對其他對象保持最少的了解
2)類與類關(guān)系越密切,耦合度越大
3)迪米特法則又叫最少直到原則义桂,即一個類對自己依賴的類知道的越少越好颊艳,也就是說肾筐,對于被依賴的類不管多么復雜,都盡量將邏輯封裝在類的內(nèi)部娇斑。對外出了提供的public方法策添,不對外泄漏任何消息
4)迪米特法則還有個更簡單的定義:只與直接的朋友通信
直接的朋友:每個對象都會其他對象有耦合的關(guān)系,只要兩個對象之間有耦合關(guān)系毫缆,我們就說這兩個對象之間是朋友關(guān)系唯竹。耦合的關(guān)系很多:依賴,關(guān)聯(lián)苦丁,組合浸颓,聚合等。其中出現(xiàn)在成員變量旺拉,方法參數(shù)产上,方法返回值中的類為直接的朋友,而出現(xiàn)局部變量中的類不是直接的朋友蛾狗。也就是說晋涣,陌生的類最好不要以局部變量的形式出現(xiàn)在類的內(nèi)部
public class Demeter {
public static void main(String[] args) {
System.out.println("");
SchoolManager schoolManager = new SchoolManager();
schoolManager.printAllEmployee(new CollegeManager());
}
}
class Employee{
private String id;
public void setId(String id){
this.id = id;
}
public String getId(){
return id;
}
}
class CollegeEmployee{
private String id;
public void setId(String id){
this.id = id;
}
public String getId(){
return id;
}
}
class CollegeManager{
public List<CollegeEmployee> getAllEmployee(){
List<CollegeEmployee> list = new ArrayList<>();
for(int i = 0; i < 10; i++){
CollegeEmployee emp = new CollegeEmployee();
emp.setId("CollegeEmployee" + i);
list.add(emp);
}
return list;
}
public void printEmployee(){
List<CollegeEmployee> list = getAllEmployee();
for(CollegeEmployee e: list){
System.out.println(e.getId());
}
}
}
class SchoolManager{
public List<Employee> getAllEmployee(){
List<Employee> list = new ArrayList<>();
for(int i = 0;i < 5;i++){
Employee emp = new Employee();
emp.setId("Employee" + i);
list.add(emp);
}
return list;
}
void printAllEmployee(CollegeManager sub){
sub.printEmployee();
List<Employee> list2 = this.getAllEmployee();
for(Employee e:list2){
System.out.println(e.getId());
}
}
}
// 運行結(jié)果
CollegeEmployee0
CollegeEmployee1
CollegeEmployee2
CollegeEmployee3
CollegeEmployee4
CollegeEmployee5
CollegeEmployee6
CollegeEmployee7
CollegeEmployee8
CollegeEmployee9
Employee0
Employee1
Employee2
Employee3
Employee4
迪米特法則注意事項和細節(jié)
1)迪米特法則的核心是降低類之間的耦合
2)但是注意:由于每個類都減少了不必要的依賴,因此迪米特法則只是要求降低類間(對象間)耦合關(guān)系沉桌,并不是要求完全沒有依賴關(guān)系