迪米特法则
程序员文章站
2022-05-18 22:25:40
个人博客原文: "迪米特法则" 设计模式六大原则之五:迪米特法则。 简介 姓名 :迪米特法则 英文名 :Law of Demeter 小名 :最少知识原则 小名英文名 :Least Knowledge Principle 价值观 :妈妈说不和陌生人说话 个人介绍 : 1. Each unit sho ......
迪米特法则
1 基本介绍
- 一个对象应该对其他对象保持最少的了解
- 类与类关系越密切,耦合度越大
- 迪米特法则(Demeter principle)又叫做最少知道原则,即一个类对自己以来的类知道得越少越好,也就是说,对于被依赖的类不管多么复杂,都尽量将逻辑封装在类的内部,对外除了提供public方法外,不对外泄露任何信息
- 迪米特法则更为简单的定义:只与直接朋友通信
- 直接朋友:每个对象都会与其他对象有耦合关系,只要两个对象之间有耦合关系,我们就说这两个对象之间是朋友关系。耦合的方式很多,依赖、关联、组合、聚合等等,其中我们称出现在在成员变量、方法参数、方法返回值中的类为直接的朋友,而出现在局部变量中的类不是直接朋友。也就是说,陌生的类最好不要以局部变量的形式出现在类的内部。
2 核心
- 降低类之间的耦合
- 注意:由于每个类都减少了不必要的依赖,因此迪米特法则只是要求降低类之间的耦合关系(对象间),并不是要求完全没有依赖关系
3 示例代码
package com.tj.demeter.normal;
import java.util.List;
public class Student {
private int id;
private String sName;
public Student() {
}
public Student(int id, String sName) {
this.id = id;
this.sName = sName;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getsName() {
return sName;
}
public void setsName(String sName) {
this.sName = sName;
}
@Override
public String toString() {
return "Student{" +
"id=" + id +
", sName='" + sName + '\'' +
'}';
}
}
package com.tj.demeter.normal;
import java.util.ArrayList;
import java.util.List;
public class StudentManager {
//初始化学生信息
public List<Student> getAllStudent() {
List<Student> list = new ArrayList<>();
for (int i = 0; i < 10; i++) {
Student student = new Student();
student.setId(i);
list.add(student);
}
return list;
}
}
package com.tj.demeter.normal;
import java.util.List;
public class School {
// 打印输出Student的所有信息
public void printAll( StudentManager studentManager) {
List<Student> list = studentManager.getAllStudent();
for (Student student : list) {
System.out.println(student);
}
}
// 分析:这里违背了迪米特法则,因为在School类中,直接朋友是StudentManager,而Student则是陌生朋友。
}
// ================测试类
package com.tj.demeter.normal;
public class Test {
public static void main(String[] args) {
StudentManager studentManager = new StudentManager();
School school = new School();
school.printAll(studentManager);
}
}
- 解决方案
package com.tj.demeter.improve;
import java.util.ArrayList;
import java.util.List;
public class StudentManager {
//初始化学生信息
public List<Student> getAllStudent() {
List<Student> list = new ArrayList<>();
for (int i = 0; i < 10; i++) {
Student student = new Student();
student.setId(i);
list.add(student);
}
return list;
}
public void printAllStudent() {
List<Student> allStudent = getAllStudent();
for (Student student : allStudent) {
System.out.println(student);
}
}
}
package com.tj.demeter.improve;
import java.util.List;
public class School {
// 打印输出Student的所有信息
public void printAll( StudentManager studentManager) {
studentManager.printAllStudent();
}
}
本文地址:https://blog.csdn.net/solo_jie/article/details/111990743
推荐阅读
-
基于Python实现迪杰斯特拉和弗洛伊德算法
-
埃迪蒙托·德·亚米契斯是谁?意大利儿童文学家亚米契斯简介
-
java设计模式--迪米特法则
-
20.7.17 笔记算数运算符 复合运算符重载 比较运算重载 多态 设计原则 类的单一职责 依赖倒置 组合复用原则 里氏替换 迪米特法则 矩阵转置原理
-
闪米特人:用来指代民族语属于亚非语系闪米特语族的人群
-
闪米特人的起源是什么?闪米特人是怎么发展起来的
-
腓尼基人:西部闪米特人的西北分支,创立了腓尼基字母
-
闪米特人有着怎样的宗教信仰?闪米特人的世界观是怎么样的
-
米家投影仪/激光电视开启“十一”特惠:最高降价4999元
-
迪杰斯特拉(Dijkstra)算法(Python)