当前位置:网站首页>接口隔离原则
接口隔离原则
2022-06-27 00:44:00 【华为云】
接口隔离原则(Interface Segregation Principle),简称ISP,定义
客户端不应该依赖它不需要的接口。一个类对另一个类的依赖应该建立在最小的接口上。
以上就是接口隔离原则的定义,换句简单的话来说,就是一个类,去实现一个接口的时候,不要去实现这个类根本不需要的方法。
案例:
假如一个厂家要生产一个电饭煲,在我们的认知中电饭煲有什么功能,比如说,电饭煲有煮饭模式、有煮粥模式、煲汤模式,当然不同的电饭煲根据它不同的价格,它们拥有的功能也大不相同。
现在有两款电饭煲,一款可以煮饭、煮粥,一款可以煮饭和煲汤,那用UML类图应该如何表示
看类图,因为电饭煲的接口,已经把所有电饭煲的功能都已经定义了,如果一个电饭煲要生产,那就去继承电饭煲的接口,但是这个电饭煲可能没有某些功能,比如JavaCooker只有煮饭和煮粥的功能,不能煮汤,但是他继承Cooker接口,必须把煮汤的接口也实现,那怎么办?返回null,如下
public interface Cooker { void cookRice(); void cookPorridge(); void cookSoup();}public class JavaCooker implements Cooker { @Override public void cookRice() { System.out.println("使用JavaCooker煮饭"); } @Override public void cookPorridge() { System.out.println("使用JavaCooker煮粥"); } @Override public void cookSoup() { }}public class PyCooker implements Cooker{ @Override public void cookRice() { System.out.println("使用PyCooker煮饭"); } @Override public void cookPorridge() { } @Override public void cookSoup() { System.out.println("使用PyCooker煮汤"); }}上面这种设计,就是和接口隔离相违背的,接口隔离原则规定,一个类如果去继承一个接口,那这些接口应该都是应该去实现的,而不是空着或者返回null,这样的写法,会在父类调用时,可能会调用到为空的子类,造成不可估计的后果。
那应该怎么去改造?
类图如下:
把应该电饭煲,所有功能,定义到一个接口,如果一个类需要什么功能,就去继承对应的接口,实现对应的方法。
接口隔离原则的意义:
接口隔离原则是为了避免接口的臃肿,如果把所有功能都集中到一个接口当中,随着产品功能不停的增加,接口内的功能也在增加,接口将会越来越臃肿,增加一个功能,每个实现这个接口的子类都得修改。
“接口隔离”其实就是定制化服务设计的原则。使用接口的多重继承实现对不同的接口的组合,从而对外提供组合功能—达到“按需提供服务”。 接口即要拆,但也不能拆得太细,这就得有个标准,这就是高内聚。接口应该具备一些基本的功能,能独一完成一个基本的任务。
边栏推荐
- 自定义类加载器对类加密解密
- Kept to implement redis autofailover (redisha) 16
- 世界很大,有人把二维码纹在脖子上
- 数据库面试题+sql语句解析
- Amazon ElastiCache 飞速搭建缓存服务集群,这才叫快
- BootstrapBlazor + FreeSql实战 Chart 图表使用(2)
- Employment prospect of GIS and remote sensing specialty and ranking selection of universities in 2022
- NLP:Transformer在NLP自然语言领域的简介(预训练技术)、NLP模型发展(ELmo/GPT/BERT/MT-DNN/XLNet/RoBERTa/ALBERT)、经典案例之详细攻略
- IIS deploy static web site and FTP service
- Find the minimum value in the rotation sort array ii[classical Abstract dichotomy + how to break the game left, middle and right are equal]
猜你喜欢

One click acceleration of Sony camera SD card file copy operation, file operation batch processing tutorial

LeetCode 142. Circular linked list II

BootstrapBlazor + FreeSql实战 Chart 图表使用(2)

LeetCode 142. 环形链表 II

Two days of beautiful butterfly animation

Flink practical problems (VII): no watermark (watermarks are only available eventtime is used)

滑环安装有哪些技巧和方法

其他服务注册与发现

How to measure the thickness of glass substrate by spectral confocal

Esp32 experiment - self built web server distribution network 02
随机推荐
Xiaobai looks at MySQL -- installing MySQL in Windows Environment
Keepalived 实现 Redis AutoFailover (RedisHA)12
对象的访问机制及其他
Keepalived 实现 Redis AutoFailover (RedisHA)11
XSS笔记(下)
30 MySQL tutorial MySQL storage engine overview
flutter系列之:flutter中的flow
memcached基础6
建模规范:环境设置
Esp32 add multi directory custom component
Object access mechanism and others
At present, which securities company is the best and safest to open an account for stock speculation?
BootstrapBlazor + FreeSql实战 Chart 图表使用(2)
用代码生成流程图,Markdown的使用方法
理想L9产品力分析:售价45.98万,采用四缸发动机,续航1315公里
Custom jsp[if, foreach, data, select] tag
Kept to implement redis autofailover (redisha) 15
The world is very big. Some people tattoo QR codes on their necks
Memcached foundation 3
Keepalived 实现 Redis AutoFailover (RedisHA)13