面向接口编程与面向实现编程

原创 2016年04月26日 17:02:37

面向接口编程与面向实现编程

最近拜读了四人组的经典名作《设计模式 可复用面向对象软件的基础》一书,打算以博客的形式进行笔记与思考


书中提到了可复用面向对象设计的原则,其中的第一个原则是:

针对接口编程,而不是针对实现编程

其实在使用面向对象语言进行编程的时候,经常不经意间就会涉及书中提到的知识,但是一旦用专门的词汇进行描述时,第一反应就是“诶?这是什么意思?看不懂啊”,只有经过反复的阅读与思考,才意识到这是日常编程经常遇到的问题,并且得到更深的理解

面向实现编程

举个例子,假设有两种品牌的轮胎,普利司通(Bridgestone)和米其林(Michelin),而轮胎的共同特性都是会转(roll)。那么我们可以得到两个类:

class Bridgestone {
    public void roll() {
        System.out.print("Bridgestone is rolling.");
    }
}

class Michelin {
    public void roll() {
        System.out.print("Michelin is rolling");
    }
}

对于一辆装了普利司通轮胎的汽车(Car),汽车的转动(roll)就是轮胎的转动:

class Car {
    public void roll(Bridgestone tire) {
        tire.roll();
    }
}

那如果我装了米其林的轮胎呢?

Car car = new Car();
Michelin tire = new Mechilin();
car.roll(tire);

显而易见,程序将会出错。这就是面向实现编程,变量是指向特定类的实例的。
这种强烈的依赖关系将会大大地抑制编程的灵活性和可复用性。


面向接口编程

如果将这两种轮胎的共同特性提取出来,在转动轮胎的时候,只关注“是轮胎”本身,而不去了解“是什么品牌的轮胎”,问题就迎刃而解了

interface Tire {
    public void roll();
}

class Bridgestone implements Tire {
    public void roll() {
        System.out.print("Bridgestone is rolling.");
    }
}

class Michelin implements Tire {
    public void roll() {
        System.out.print("Michelin is rolling");
    }
}

接口Tire定义了“转动”这个接口,但把实现延迟到了子类中

class Car {
    public void roll(Tire tire) {
        tire.roll();
    }
}

Car car = new Car();
BridgeStone tire1 = new Bridgestone();
Michelin tire2 = new Mechilin();
car.roll(tire1);
car.roll(tire2);

汽车在转动时,并不关注“是什么品牌的轮胎“,只关注”是轮胎“,想怎么转就怎么转

从这个例子我们可以看出,面向接口编程的特性:

客户无须知道他们使用对象的特定类型,只须对象有客户所期望的接口

客户使用汽车转动轮胎时,无须知道轮胎的特定类型(品牌,对应的子类),只要轮胎有客户所期望的接口(roll)就行了

客户无须知道他们使用的对象是用什么类来实现的,他们只须知道定义接口的抽象类

客户使用Car的roll方法调用轮胎对应的方法时,不需要知道这个轮胎实例是用什么子类实现的,他只需要知道定义转动方法的抽象类(JAVA中的interface)的内容就行了


总结

面向接口的编程方式是面向对象设计的一个原则,使用这种编程思想,我们可以容易地写出具有可复用性的代码,这对于代码的理解和维护具有很大的帮助

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u013400743/article/details/51252003

Java面向对象

这门课程是让初学者开始接触面向对象编程思想,为日后的项目开发做准备。
  • 2017年01月30日 17:10

面向接口编程的优点

1 首先什么是面向接口编程? 面向接口编程就是先把客户的业务逻辑线提取出来,作为接口,业务具体实现通过该接口的实现类来完成。当客户需求变化时,只需编写该业务逻辑的新的实现类,通过更改配置文件(例如...
  • JJ_nan
  • JJ_nan
  • 2017-04-13 19:04:43
  • 7273

一篇非常经典的文章(面向接口编程)

原文链接:http://blog.chinaunix.net/uid-20478213-id-1942005.html 面向对象设计里有一点大家已基本形成共识,就是面向接口编程,我想大多数人对这个是...
  • legend404
  • legend404
  • 2016-10-14 10:10:04
  • 4344

面向接口编程(或者面向抽象编程)的一个例子。

面向接口编程的一个例子。
  • csdn372301467
  • csdn372301467
  • 2017-08-23 09:43:56
  • 916

如何理解“面向接口的编程”

经常听说“面向接口编程”,但并不是特别的理解。什么时候应该面向接口编程? 当我一开始接触暴露出的接口的时候,我很困惑,并不知道为什么需要他们。如果我们使用Java或者c#,我们已经有了继承这个概...
  • gusgao
  • gusgao
  • 2016-07-22 23:03:39
  • 1792

面向接口编程的设计模式

面向接口编程的设计模式简单工厂模式 假设程序中有个Computer类需要组合一个输出设备,现在有两个选择:直接让Computer类组合一个Printer,或者让Computer类组合一个Output,...
  • greenlihui
  • greenlihui
  • 2017-03-13 13:18:53
  • 1257

为什么web项目里面都是面向接口编程的啊?

开发java快2年了,今天忽然发现一个问题,我的web项目都是一个接口对应一个实现类。 这样的接口还有意义吗? 我觉得是没有任何意义的,一个接口对应一个实现类,唯一的好处就是实现类会提示接口的那个...
  • u010523770
  • u010523770
  • 2016-09-06 19:22:40
  • 1157

由最简单的例子理解接口的实例化和面向接口编程

主要写写自己对接口实例化的理解:关于接口大家应该都清楚,类实现接口必须实现接口的所有方法,属性除外。那么既然有类来实例化接口,那么为什么还要把类的实例转换为接口,也就是我们所说的接口的实例化。这样一来...
  • programming_snail
  • programming_snail
  • 2016-01-09 15:29:19
  • 3571

对面向接口编程的理解

面向对象设计里有一点大家已基本形成共识,就是面向接口编程,我想大多数人对这个是没有什么觉得需要怀疑的。      问题是在实际的项目开发中我们是怎么体现的呢? 难道就是每一个实现都提供一个接口就...
  • paul342
  • paul342
  • 2015-08-04 09:34:47
  • 4770

为什么要面向接口编程

接口描述: 接口,即对实现类的一种规范,当一个具体实现类实现这个接口的时候,应当实现接口所定义的所有规范。 那为什么要面向接口编程呢? 答案和使用spring是一样的,降低代码耦合度,提高克扩展性,...
  • yym836659673
  • yym836659673
  • 2017-07-02 10:58:42
  • 1107
收藏助手
不良信息举报
您举报文章:面向接口编程与面向实现编程
举报原因:
原因补充:

(最多只允许输入30个字)