软件设计原则-接口隔离原则讲解以及代码示例
接口隔离原则
一,介绍
1.前言
接口隔离原则(Interface Segregation Principle,ISP)是面向对象设计中的一个原则,提倡使用多个专门的接口,而不使用单一的大接口。它最早由Robert C. Martin在其《敏捷软件开发:原则、模式与实践》一书中提出。
接口隔离原则的核心思想是:客户端不应该依赖于它不需要的接口。也就是说,一个类或模块不应该强迫它的用户去依赖无用的接口。相反,应该将大接口拆分成多个小接口,符合客户端的需求,使客户端只依赖于它真正需要的接口。
接口隔离原则的目标是降低类或模块之间的耦合度,提高代码的可维护性、可扩展性和可测试性。通过使用多个专门的接口,我们可以避免类或模块之间出现不必要的依赖关系,减少对无用接口的实现或调用,从而降低了修改和维护的成本。
2.何时使用接口隔离原则
-
接口职责不一致:当一个接口承担了多个不相关的职责时,可能导致实现该接口的类需要实现它们不需要的方法,这违反了接口隔离原则。此时,可以考虑将该接口拆分为多个细粒度的接口,每个接口只包含相关的方法。由于客户端仅依赖于它们需要的接口,这样可以减少对无关方法的依赖性,提高代码的灵活性和可维护性。
-
接口庞大臃肿:如果一个接口包含大量的方法,其庞大的接口定义可能会给实现类带来负担。在这种情况下,可以将接口分解为多个更小的接口,每个接口都有一个清晰的责任。这样可以降低实现类的复杂度,并且有助于提高代码的可读性、可维护性和可扩展性。
-
接口实现冗余:有时候一个类只需要使用接口的部分方法,但由于接口的设计不合理,需要实现整个接口。这样会导致实现类冗余地实现了一些不需要的方法。通过采用接口隔离原则,可以将接口拆分为多个更小的接口,使得实现类只需实现自己需要的接口,避免了冗余代码的产生。
-
接口变更频繁:当一个接口发生变化时,所有依赖该接口的类都需要进行相应的修改,这可能带来大量的工作量。接口隔离原则可以将接口细化为更小的粒度,从而使得接口的变更影响范围更小,降低了耦合性,提高了系统的稳定性和可维护性。
二,代码示例
为了更好地理解接口隔离原则,我们可以通过一个例子来说明:
假设我们正在设计一个文件系统的接口,其中包含读取文件、写入文件、删除文件等操作。我们可以设计一个名为`FileSystem`的接口来表示文件系统,如下所示:
interface FileSystem {void read(String fileName);void write(String fileName, String content);void delete(String fileName);
}
在这个设计中,`FileSystem`接口包含了读取、写入和删除文件三个操作。但是,如果我们有一个只需要读取文件的客户端,它却不需要写入或删除文件的功能,那么它就不得不实现空方法或抛出异常,这违反了接口隔离原则。
为了符合接口隔离原则,我们可以将大接口拆分成多个小接口,每个接口只包含一个职责或功能,如下所示:
interface Readable {void read(String fileName);
}interface Writable {void write(String fileName, String content);
}interface Deletable {void delete(String fileName);
}
通过拆分接口,我们可以根据客户端的需求给予其相应的小接口,避免了不必要的方法实现或调用。对于只需要读取文件的客户端,它只需要实现`Readable`接口即可,无需关心其他不需要的操作。
总结起来,接口隔离原则要求我们设计多个专门的接口,而不是使用单个臃肿的大接口。通过拆分接口,我们能够减少类或模块之间的耦合度,提高代码的灵活性和可维护性。符合接口隔离原则的设计能够更好地满足客户端的需求,减少不必要的方法实现或调用,使系统更加稳定和可靠。
三,优缺点
接口隔离原则(Interface Segregation Principle,ISP)是面向对象设计中的一个原则,它强调客户端不应该强制依赖于它们不需要使用的接口。接口隔离原则具有以下优点和缺点:
优点:
1. 提高代码的灵活性:接口隔离原则通过将大型接口拆分为多个小型接口,使得客户端只需依赖于自己需要的接口,从而避免了不必要的依赖和耦合。这提高了代码的灵活性,使得系统更容易修改、扩展和维护。
2. 提高代码的可读性和可理解性:借助接口隔离原则,每个接口都有明确的职责和功能。这使得代码的结构更加清晰,减少了冗余方法和不必要的复杂性。开发人员可以更轻松地理解接口的用途和作用,提高了代码的可读性和可理解性。
3. 降低变更的风险:当需要修改一个接口时,由于接口已经被细化为多个小型接口,变更的影响范围相对较小。这降低了引入错误和破坏现有功能的风险,使得系统更加稳定可靠。
4. 增强代码的复用性:接口隔离原则使得每个接口都具有单一的职责,这使得接口更加精确地描述了特定的功能和行为。这样,其他模块或类可以更容易地复用这些小型接口,提高了代码的复用性。
缺点:
1. 接口数量增加:通过遵循接口隔离原则,系统中可能会出现更多的接口。这增加了接口的数量,使得接口的管理和维护工作变得更加复杂。需要在设计时权衡接口数量的增加和维护的成本。
2. 接口拆分所带来的复杂性:如果接口隔离不当,将接口拆分为过多的细粒度接口可能会导致类之间的关系变得复杂。在设计过程中,需要仔细考虑接口的划分方式,确保接口的粒度适中,避免过度拆分导致代码的繁琐性。
总结起来,接口隔离原则通过细化接口,使其职责更加明确和一致,能够提高代码的灵活性、可读性和可理解性,降低变更的风险,增强代码的复用性。然而,需要注意接口数量的增加和接口拆分带来的复杂性问题,使得设计合理且易于维护。
相关文章:
软件设计原则-接口隔离原则讲解以及代码示例
接口隔离原则 一,介绍 1.前言 接口隔离原则(Interface Segregation Principle,ISP)是面向对象设计中的一个原则,提倡使用多个专门的接口,而不使用单一的大接口。它最早由Robert C. Martin在其《敏捷软件…...
yolov8x-p2 实现 tensorrt 推理
简述 在最开始的yolov8提供的不同size的版本,包括n、s、m、l、x(模型规模依次增大,通过depth, width, max_channels控制大小),这些都是通过P3、P4和P5提取图片特征; 正常的yolov8对象检测模型输出层是P3、…...
Type Script的变量类型
Typescript 的重要特性之一就是数据有类型了。 常见的类型如:字符串、数值、布尔等都有了明确的定义。 变量声明的格式 let 变量名:类型 初始值;字符型 let str:string "abc";数值型 数值型也支持不同的进制,用前缀区分 支持 整…...
系统架构师备考倒计时13天(每日知识点)
1. 数据仓库四大特点 面向主题的。操作型数据库的数据组织面向事务处理任务,各个业务系统之间各自分离,而数据仓库中的数据是按照一定的主题域进行组织的。集成的。数据仓库中的数据是在对原有分散的数据库数据抽取、清理的基础上经过系统加工、汇总和整…...
20 | Spring Data JPA 中文文档
Spring Data JPA 中文文档 1. 前言 Spring Data JPA 为 Jakarta Persistence API(JPA)提供 repository 支持。它简化了需要访问JPA数据源的应用程序的开发。 1.1. 项目元数据 版本控制: https://github.com/spring-projects/spring-data-jpaBug跟踪:…...
【AOA-VMD-LSTM分类故障诊断】基于阿基米德算法AOA优化变分模态分解VMD的长短期记忆网络LSTM分类算法(Matlab代码)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
K8s:Pod 中 command、args 与 Dockerfile 中 CMD、 ENTRYPOINT 的对应关系
写在前面 前几天被问到,这里整理笔记之前也没怎么注意这个问题理解不足小伙伴帮忙指正 曾以为老去是很遥远的事,突然发现年轻是很久以前的事了。时光好不经用,抬眼已是半生,所谓的中年危机,真正让人焦虑的不是孤单、不…...
Visual Studio Code (VS Code)安装教程
Visual Studio Code(简称“VS Code”)。 1.下载安装包 VS Code的官网: Visual Studio Code - Code Editing. Redefined 首先提及一下,vscode是不需要破解操作的; 第一步,看好版本,由于我的系…...
技巧 | 如何解决 zsh: permission denied 问题 | Mac
技巧 | 如何解决 zsh: permission denied 问题 | Mac 问题描述 在 macOS 系统终端执行 sh 程序脚本时,抛出异常 zsh: permission denied 原因分析 用户没有权限,所以才出现了这个错误,所以只需要用 chmod 修改一下权限就可以了 解决方法…...
【JavaEE】线程安全的集合类 -- 多线程篇(9)
线程安全的集合类 多线程环境使用 ArrayList多线程环境使用队列多线程环境使用哈希表 多线程环境使用 ArrayList 自己使用同步机制 (synchronized 或者 ReentrantLock)Collections.synchronizedList(new ArrayList); synchronizedList 是标准库提供的一个基于 synchronized 进…...
【MySQL架构篇】MySQL字符集、大小写规范及默认数据库
文章目录 1. 字符集与字符集比较规则2. 大小写规范3. 默认数据库4. 与文件系统相关 1. 字符集与字符集比较规则 MySQL有4个级别的字符集和比较规则,分别是 服务器级别数据库级别表级别列级别 当创建对应表或列未指定字符集时,默认会取其上一级别的字符…...
【Linux系统编程】命令模式2
目录 一,Linux下的初阶认识 1,管道 2,时间戳 二,Liunx系统命令操作 1,date时间指令 2,cal日历指令 3,which和find查找指令 3-1,which指令: 3-2,find…...
【Leetcode】【中等】1726.同积元组
力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/tuple-with-same-product/ 给你…...
Git教程
文章目录 Git 介绍GIt历史Git 安装环境配置工作区、缓存区和仓库区(版本库)工作区(工作目录)暂存区仓库区git工作目录下文件的装填 Git 生成公钥及添加到gitlab或Gerrit上Git常用命令git stautsgit statu -sgit addgit commitgit reset1. git reset --ha…...
使用序列化技术保存数据 改进 IO流完成项目实战水果库存系统
上一节内容是 使用IO流完成项目实战水果库存系统https://blog.csdn.net/m0_65152767/article/details/133999972?spm1001.2014.3001.5501 package com.csdn.fruit.pojo; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import java…...
0基础学习PyFlink——使用PyFlink的Sink将结果输出到外部系统
在《0基础学习PyFlink——使用PyFlink的SQL进行字数统计》一文中,我们直接执行了Select查询操作,在终端中直接看到了查询结果。 select word, count(1) as count from source group by word; ------------------------------------------------------ |…...
会声会影2024旗舰版详细功能介绍
随着网络视频的蓬勃发展,越来越多的人开始涉足视频剪辑领域,毕竟技多不压身嘛。在众多剪辑软件中,剪映和会声会影是备受新手青睐的两种。那么,会声会影和剪映哪个好呢?在它们之间,哪一个更适合初学者呢接&a…...
QtCreator 查看类帮助文档,快捷键操作:按两次F1 全屏帮助,Esc取消全屏
如何查看类帮助文档 选择类,按F1查看类帮助文档。 示例: #include <QLabel> // 将光标放在QLabel上,按F1右侧弹出的类帮助手册可视宽度很小,如果按两次 F1 键,帮助文档将会以全屏模式显示,以便更清…...
C语言文件操作(1)
C语言文件操作(1) 文章目录 C语言文件操作(1)一、理解文件1.概述2.分类①.正常角度②.文本文件和二进制文件 二、文件的打开和关闭1.流和标准流2.文件类型指针3.文件的打开和关闭以及使用类型 三、文件缓冲区 一、理解文件 1.概述…...
adb 操作命令(adb调试QT项目使用到的命令)
1.adb连接串口 获取root权限 adb root && adb remount && adb shell2.测试串口命令 stty -F /dev/ttyS4 cs8 -parenb -cstopb -echoecho "12345\n" > /dev/ttyS8cat /dev/ttyS4 &3.软件在安卓系统上的名字已经活动名称(下面是示…...
Qt Widget类解析与代码注释
#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码,写上注释 当然可以!这段代码是 Qt …...
从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路
进入2025年以来,尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断,但全球市场热度依然高涨,入局者持续增加。 以国内市场为例,天眼查专业版数据显示,截至5月底,我国现存在业、存续状态的机器人相关企…...
什么是库存周转?如何用进销存系统提高库存周转率?
你可能听说过这样一句话: “利润不是赚出来的,是管出来的。” 尤其是在制造业、批发零售、电商这类“货堆成山”的行业,很多企业看着销售不错,账上却没钱、利润也不见了,一翻库存才发现: 一堆卖不动的旧货…...
Spring AI 入门:Java 开发者的生成式 AI 实践之路
一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…...
鱼香ros docker配置镜像报错:https://registry-1.docker.io/v2/
使用鱼香ros一件安装docker时的https://registry-1.docker.io/v2/问题 一键安装指令 wget http://fishros.com/install -O fishros && . fishros出现问题:docker pull 失败 网络不同,需要使用镜像源 按照如下步骤操作 sudo vi /etc/docker/dae…...
RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)
RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发,后来由Pivotal Software Inc.(现为VMware子公司)接管。RabbitMQ 是一个开源的消息代理和队列服务器,用 Erlang 语言编写。广泛应用于各种分布…...
逻辑回归暴力训练预测金融欺诈
简述 「使用逻辑回归暴力预测金融欺诈,并不断增加特征维度持续测试」的做法,体现了一种逐步建模与迭代验证的实验思路,在金融欺诈检测中非常有价值,本文作为一篇回顾性记录了早年间公司给某行做反欺诈预测用到的技术和思路。百度…...
从 GreenPlum 到镜舟数据库:杭银消费金融湖仓一体转型实践
作者:吴岐诗,杭银消费金融大数据应用开发工程师 本文整理自杭银消费金融大数据应用开发工程师在StarRocks Summit Asia 2024的分享 引言:融合数据湖与数仓的创新之路 在数字金融时代,数据已成为金融机构的核心竞争力。杭银消费金…...
日常一水C
多态 言简意赅:就是一个对象面对同一事件时做出的不同反应 而之前的继承中说过,当子类和父类的函数名相同时,会隐藏父类的同名函数转而调用子类的同名函数,如果要调用父类的同名函数,那么就需要对父类进行引用&#…...
给网站添加live2d看板娘
给网站添加live2d看板娘 参考文献: stevenjoezhang/live2d-widget: 把萌萌哒的看板娘抱回家 (ノ≧∇≦)ノ | Live2D widget for web platformEikanya/Live2d-model: Live2d model collectionzenghongtu/live2d-model-assets 前言 网站环境如下,文章也主…...
