「撸一手好代码」设计模式之接口隔离原则

「撸一手好代码」设计模式之接口隔离原则

什么是接口隔离原则

接口隔离原则(Interface Segregation Principle, ISP)指出,客户端不应该依赖它不使用的接口。换句话说,一个类对另一个类的依赖应该建立在最小的接口上。接口的设计应该尽量细化,每个接口只包含客户端所需的方法,而不是提供一个庞大臃肿的接口,迫使客户端依赖于它们不使用的方法。

为什么需要接口隔离原则

接口隔离原则的重要性体现在以下几个方面:

  1. 降低耦合度:细化接口可以减少类之间的依赖关系,降低系统的耦合度。
  2. 提高灵活性:当接口发生变化时,由于依赖关系的减少,受影响的类也会相应减少,提高了系统的灵活性。
  3. 易于维护和扩展:接口细化后,每个接口都更加专注于特定的功能,使得系统的维护和扩展变得更加容易。

如何应用接口隔离原则

在实际开发中,应用接口隔离原则需要注意以下几点:

  1. 识别客户端需求:首先,明确各个客户端的具体需求,了解它们需要哪些方法。
  2. 细化接口:根据客户端需求,将接口细化成多个小接口,每个接口只包含一组紧密相关的方法。
  3. 建立依赖关系:让客户端依赖于它们需要的接口,而不是依赖于一个庞大的接口。

接口隔离原则示例

反例(以Java代码为例)

以动物为例,有些动物能游泳,有些能飞。如果把所有的行为都定义在Animal接口中,必然导致部分动物无法实现其中部分行为。从另外一个角度,其又违背了里氏替换原则。

java 复制代码
public interface Animal {

    void eat();

    void sleep();

    void fly();
}
java 复制代码
public class Bird implements Animal{
    @Override
    public void eat() {
        System.out.println("Bird is eating");
    }

    @Override
    public void sleep() {
        System.out.println("Bird is sleeping");
    }

    @Override
    public void fly() {
        System.out.println("Bird is flying");
    }
}
java 复制代码
public class Dog implements Animal{

    @Override
    public void eat() {
        System.out.println("Dog is eating");
    }

    @Override
    public void sleep() {
        System.out.println("Dog is sleeping");
    }

    @Override
    public void fly() {
        System.out.println("Dog can't fly");
    }
}

后果

  • 系统耦合度增加,难以维护和扩展。
  • 当接口发生变化时,可能会影响多个不相关的客户端。

解决方案

  1. 细化接口:将一些特有的行为进行接口分离,定义独立的Flyable飞行能力接口。
  2. 重新设计客户端:让客户端依赖于它们真正需要的接口,而不是一个庞大的接口。
  3. 使用适配器模式:如果由于某些原因无法直接修改现有代码,可以使用适配器模式来封装不符合接口隔离原则的接口,为客户端提供一个符合其需求的更细化的接口。
java 复制代码
public interface Animal {

    void eat();

    void sleep();
}
java 复制代码
public interface Flyable {

    void fly();
}
java 复制代码
public class Bird implements Animal, Flyable {
    @Override
    public void eat() {
        System.out.println("Bird is eating");
    }

    @Override
    public void sleep() {
        System.out.println("Bird is sleeping");
    }

    @Override
    public void fly() {
        System.out.println("Bird is flying");
    }
}
java 复制代码
public class Dog implements Animal {

    @Override
    public void eat() {
        System.out.println("Dog is eating");
    }

    @Override
    public void sleep() {
        System.out.println("Dog is sleeping");
    }
}

结语

接口隔离原则是面向对象设计中一个非常重要的原则,它帮助我们设计出灵活、易维护的接口。通过遵循这一原则,我们可以降低系统的耦合度,提高灵活性,并使得系统的维护和扩展变得更加容易。

参考

https://zhuanlan.zhihu.com/p/130954951

相关推荐
JH30738 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
Coder_Boy_9 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
invicinble9 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
较真的菜鸟9 小时前
使用ASM和agent监控属性变化
java
黎雁·泠崖10 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
qq_124987075311 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
Coder_Boy_11 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Mr_sun.11 小时前
Day06——权限认证-项目集成
java
瑶山11 小时前
Spring Cloud微服务搭建四、集成RocketMQ消息队列
java·spring cloud·微服务·rocketmq·dashboard
abluckyboy11 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法