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

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

什么是接口隔离原则

接口隔离原则(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

相关推荐
sniper_fandc26 分钟前
SpringBoot系列—入门
java·spring boot·后端
代码的余温2 小时前
Maven引入第三方JAR包实战指南
java·maven·jar
pianmian15 小时前
类(JavaBean类)和对象
java
我叫小白菜5 小时前
【Java_EE】单例模式、阻塞队列、线程池、定时器
java·开发语言
Albert Edison6 小时前
【最新版】IntelliJ IDEA 2025 创建 SpringBoot 项目
java·spring boot·intellij-idea
超级小忍6 小时前
JVM 中的垃圾回收算法及垃圾回收器详解
java·jvm
weixin_446122466 小时前
JAVA内存区域划分
java·开发语言·redis
勤奋的小王同学~7 小时前
(javaEE初阶)计算机是如何组成的:CPU基本工作流程 CPU介绍 CPU执行指令的流程 寄存器 程序 进程 进程控制块 线程 线程的执行
java·java-ee
TT哇7 小时前
JavaEE==网站开发
java·redis·java-ee
2401_826097627 小时前
JavaEE-Linux环境部署
java·linux·java-ee