当前位置: 首页 > news >正文

【设计模式】软件设计原则——接口隔离迪米特

接口隔离原则引出

 接口隔离原则

定义:用多个专门的接口,不使用单一的总接口,客户端不应该依赖它不需要的接口;


一个类对另一个类的依赖,应该建立在最小接口上;如果有一个大接口,里面有很多方法,如果使用一个类实现该接口,所有的类都要实现,导致代码冗余;

建立功能单一接口,不要建立特别多功能的接口;接口设计不能过大过小,适度接口。

优点:高内聚,低耦合,类具有很好的可读性,可扩展性,可维护性;

降低耦合:平时设计接口时,只暴露客户端需要的方法,客户端不需要的方法,直接隐藏起来;
提高内聚:减少对外交互,使用接口中最少的方法,完成最多的事情;

实际开发中,对以后有可能会发生变更的地方做一些预判,抽象出业务模型。

接口隔离原则案例

public interface Animal{void eat();void fly();void walk();void swim();
}
//实现一个鸟类,swim方法是空的,造成代码冗余public class Bird implements Animal{@Overridepublic void eat() {}@Overridepublic void fly() {}@Overridepublic void walk() {}@Overridepublic void swim() {}
}

正确做法如下:

public interface IEat {void eat();
}
public interface IWalk {void walk();
}
public interface ISwim {void swim();
}
public interface IFly{void fly();
}//鸟可以飞,走,吃;不能游泳
public class Dog implements IEat,IWalk,IFly{@Overridepublic void eat() {}@Overridepublic void fly() {}@Overridepublic void walk() {}
}

迪米特原则引出


迪米特原则

定义:一个对象应该对其它对象,保持最少的了解;

尽量降低类之间的耦合;对外部引入的类,越少越好;

优点:降低了类之间的耦合;

代码层面:不要对外公开太多的public方法和变量,多使用private/protected权限;

核心观念:类的解耦,解耦是有一定程度的,尽量做到弱耦合,耦合程度越低,类的复用率才能提高;由于减少了类之间不必要的依赖,从而达到了降低了耦合的目的;

只和朋友交流,不和陌生人说话

朋友:出现在成员变量,方法的输入,输出参数中的类,称为成员朋友类;出现在方法体内部的类,不属于朋友类;也就是说类A,我使用了类A中的方法,或成员,尽量避免导致本类import导入新的类;


迪米特原则案例

老师让班长记录考勤

//老师类
public class Teacher{public void checkAttendance(Monitor monitor) {List<Student> studentList= new ArrayList<>();for (int i = 0; i < 50; i++) {studentList.add(new Student());}monitor.checkAttendance(studentList);}
}
//班长类
public class Monitor{public void checkStudentAttendance(List<Student> studentList) {System.out.println("今天有" + studentList.size()+"学生到教室");}
}
public class Student{
//学生类
}public class Main {public static void main(String[] args) {Teacher teacher= new Teacher();Monitor monitor= new Monitor();teacher.checkAttendance(monitor);}
}
//遵循迪米特原则
//Teacher直接给Monitor下指令 , Monitor去查考勤//老师类
public class Teacher{public void checAttendance(Monitor monitor) {monitor.checkAttendance();}
}
//班长类
public class Monitor{public void checkStudentAttendance(List<Student> studentList) {List<Student> studentList= new ArrayList<>();for (int i = 0; i < 50; i++) {studentList.add(new Student());}System.out.println("今天有" + studentList.size()+"学生到教室");}
}
public class Student{
//学生类
}
public class Main {public static void main(String[] args) {Teacher teacher= new Teacher ();Monitor monitor = new Monitor();teacher.checAttendance(monitor );}
}
http://www.lryc.cn/news/453180.html

相关文章:

  • 【C++】——list的介绍和模拟实现
  • B树系列解析
  • docker 部署 WEB IDE
  • 【Android】数据存储
  • 个人网络安全的几个重点与防御
  • python爬虫 - 初识爬虫
  • tomcat版本升级导致的umask问题
  • Golang | Leetcode Golang题解之第455题分发饼干
  • vscode+stfp插件,实现远程自动同步文件代码
  • python 实现djb2哈希算法
  • 文件夹作为普通文件而非子模块管理
  • 7c结构体
  • 浅聊前后端分离开发和前后端不分离开发模式
  • RabbitMQ篇(死信交换机)
  • HBase 的 MemStore 详解
  • 【嵌入式软件-数据结构与算法】01-数据结构
  • Windows应用开发-解析AVI视频文件
  • 探索TCP协议的奥秘:Python中的网络通信
  • 每日学习一个数据结构-树
  • 简单PCL库读文件(linux vscode编译)
  • 【自动驾驶】最近计划看的论文
  • vue3学习:axios输入城市名称查询该城市天气
  • 影刀RPA实战:Excel拆分与合并工作表
  • STM32三种启动模式:【详细讲解】
  • Ray_Tracing_The_Next_Week
  • DBT hook 实战教程
  • SpringBoot整合JPA详解
  • 【微服务】springboot 实现动态修改接口返回值
  • 【前端开发入门】html快速入门
  • python配置环境变量