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

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

什么是接口隔离原则

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

相关推荐
FrankYoou19 分钟前
Jenkins 与 GitLab CI/CD 的核心对比
java·docker
麦兜*1 小时前
Spring Boot启动优化7板斧(延迟初始化、组件扫描精准打击、JVM参数调优):砍掉70%启动时间的魔鬼实践
java·jvm·spring boot·后端·spring·spring cloud·系统架构
KK溜了溜了1 小时前
JAVA-springboot 整合Redis
java·spring boot·redis
天河归来1 小时前
使用idea创建springboot单体项目
java·spring boot·intellij-idea
weixin_478689762 小时前
十大排序算法汇总
java·算法·排序算法
码荼2 小时前
学习开发之hashmap
java·python·学习·哈希算法·个人开发·小白学开发·不花钱不花时间crud
IT_10242 小时前
Spring Boot项目开发实战销售管理系统——数据库设计!
java·开发语言·数据库·spring boot·后端·oracle
ye902 小时前
银河麒麟V10服务器版 + openGuass + JDK +Tomcat
java·开发语言·tomcat
武昌库里写JAVA2 小时前
Oracle如何使用序列 Oracle序列使用教程
java·开发语言·spring boot·学习·课程设计
做题不NG3 小时前
大模型应用开发-LangChain4j
java