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

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

什么是接口隔离原则

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

相关推荐
nlog3n13 分钟前
MySQL 常见面试问题总结
java·数据库·mysql·面试
小灰灰是码农...19 分钟前
java中的泛型和反射
java·反射·泛型
申尧强29 分钟前
Flink Credit-based机制解析
java·网络·flink
杨凯凡31 分钟前
Apache Shiro 全面指南:从入门到高级应用
java·后端·shiro
oioihoii1 小时前
深入解析 C++20 中的 std::bind_front:高效函数绑定与参数前置
java·算法·c++20
码递夫1 小时前
[NO-WX179]基于springboot+微信小程序的在线选课系统
java·spring boot·后端·微信小程序
magic 2451 小时前
Servlet-http协议、模版方法设计模式、HttpServlet源码分析
java·servlet·tomcat·html·intellij-idea
blammmp1 小时前
Java EE 进阶:MyBatis-plus
java·java-ee·mybatis
程序员yt1 小时前
双非一本Java方向,学完感觉Java技术含量不高,考研换方向如何选择?
java·开发语言·考研
凌冰_1 小时前
Java 集合中ArrayList与LinkedList的性能比较
java·开发语言