设计模式的七大设计原则:其二:接口隔离原则

接口隔离原则:

基本介绍:

1.客户端不应该依赖它不需要的接口,即一个类对另一个类的依赖应该建立在最小的接口上

2.先看一张图

3.类A通过Interface1依赖类B,类C通过接口Interface1依赖类D,如果接口Interface1对于类A和类C来说不是最小接口,那么类B和类D必须去实现他们不需要的方法。

4.按照接口隔离的原则应当这样处理:

将接口Interface1拆分为独立的几个接口,类A和类C分别与他们需要的接口建立依赖关系,依旧是采用接口隔离的原则。

案例:

1.接口及实现

package segregation;

public class InterfaceSegregationPrinciple {
    public static void main(String[] args) {

    }

}

interface Interface1{
    void operation1();
    void operation2();
    void operation3();
    void operation4();
    void operation5();
}

class B implements Interface1{

    @Override
    public void operation1() {
        System.err.println("B 实现了 operation1");
    }

    @Override
    public void operation2() {
        System.err.println("B 实现了 operation2");
    }

    @Override
    public void operation3() {
        System.err.println("B 实现了 operation3");
    }

    @Override
    public void operation4() {
        System.err.println("B 实现了 operation4");
    }

    @Override
    public void operation5() {
        System.err.println("B 实现了 operation5");
    }
}

class D implements Interface1{

    @Override
    public void operation1() {
        System.err.println("D 实现了 operation1");
    }

    @Override
    public void operation2() {
        System.err.println("D 实现了 operation2");
    }

    @Override
    public void operation3() {
        System.err.println("D 实现了 operation3");
    }

    @Override
    public void operation4() {
        System.err.println("D 实现了 operation4");
    }

    @Override
    public void operation5() {
        System.err.println("D 实现了 operation5");
    }
}

class A {
    public void dependence1(Interface1 i){
        i.operation1();
    }
    public void dependence2(Interface1 i){
        i.operation2();
    }
    public void dependence3(Interface1 i){
        i.operation3();
    }
}

class C{
    public void dependence1(Interface1 i){
        i.operation1();
    }
    public void dependence4(Interface1 i){
        i.operation4();
    }
    public void dependence5(Interface1 i){
        i.operation5();
    }
}

应传统方法的问题和使用接口隔离原则改进:

1)类A通过接口Interface1依赖类B,类C通过接口Interface1依赖类D,如果接口Interface1对于类A和类C来说不是最小接口,那么类和类D必须去实现他们不需要的方法。

2)将接口Interface1拆分为独立几个接口,类A和类C分别与他们需要的接口建立依赖关系。也就是采用接口隔离原则。

3)接口Interface1中出现的方法,根据实际情况拆分为三个接口

2.案例2:

类图如下:

package segregation.improve;

public class InterfaceSegregationPrinciple {
    public static void main(String[] args) {

        A a = new A();
        //A类通过接口依赖(使用)B类
        a.dependence1(new B());

        C c = new C();
        c.dependence1(new D());
    }

}

interface Interface1{
    void operation1();
}
interface Interface2{
    void operation2();
    void operation3();
}
interface Interface3{
    void operation4();
    void operation5();
}

class B implements Interface1,Interface2{

    @Override
    public void operation1() {
        System.err.println("B 实现了 operation1");
    }

    @Override
    public void operation2() {
        System.err.println("B 实现了 operation2");
    }

    @Override
    public void operation3() {
        System.err.println("B 实现了 operation3");
    }
}

class D implements Interface1,Interface3{

    @Override
    public void operation1() {
        System.err.println("D 实现了 operation1");
    }

    @Override
    public void operation4() {
        System.err.println("D 实现了 operation4");
    }

    @Override
    public void operation5() {
        System.err.println("D 实现了 operation5");
    }
}

class A {
    public void dependence1(Interface1 i){
        i.operation1();
    }
    public void dependence2(Interface2 i){
        i.operation2();
    }
    public void dependence3(Interface2 i){
        i.operation3();
    }
}

class C{
    public void dependence1(Interface1 i){
        i.operation1();
    }
    public void dependence4(Interface3 i){
        i.operation4();
    }
    public void dependence5(Interface3 i){
        i.operation5();
    }
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值