接口隔离原则

接口隔离原则(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,这样的写法,会在父类调用时,可能会调用到为空的子类,造成不可估计的后果。

那应该怎么去改造?
类图如下:
在这里插入图片描述
把应该电饭煲,所有功能,定义到一个接口,如果一个类需要什么功能,就去继承对应的接口,实现对应的方法。

接口隔离原则的意义:

接口隔离原则是为了避免接口的臃肿,如果把所有功能都集中到一个接口当中,随着产品功能不停的增加,接口内的功能也在增加,接口将会越来越臃肿,增加一个功能,每个实现这个接口的子类都得修改。

“接口隔离”其实就是定制化服务设计的原则。使用接口的多重继承实现对不同的接口的组合,从而对外提供组合功能—达到“按需提供服务”。 接口即要拆,但也不能拆得太细,这就得有个标准,这就是高内聚。接口应该具备一些基本的功能,能独一完成一个基本的任务。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

i进击的攻城狮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值