我读过的几乎每一本Java书都谈到了使用接口作为在对象之间共享状态和行为的方法,而这些对象在第一次“构造”时似乎并不共享关系。
然而,每当我看到架构师设计应用程序时,他们做的第一件事就是开始对接口进行编程。怎么会这样?您如何知道将在该接口中出现的对象之间的所有关系?如果您已经知道这些关系,那么为什么不直接扩展一个抽象类呢?
发布于 2008-09-07 17:46:52
对接口进行编程意味着遵守通过使用该接口创建的“契约”。因此,如果您的IPoweredByMotor接口有一个start()方法,那么将来实现该接口的类,无论是MotorizedWheelChair、Automobile还是SmoothieMaker,在实现该接口的方法时,都会为您的系统增加灵活性,因为一段代码可以启动许多不同类型的东西,因为这段代码需要知道的就是它们对start()做出响应。他们如何开始并不重要,重要的是他们必须开始。
发布于 2008-09-08 07:57:52
问得好。我将向您推荐Josh Bloch in Effective Java,他写了(第16条)为什么更喜欢使用接口而不是抽象类。顺便说一句,如果你还没有读到这本书,我强烈推荐它!以下是他所说的话的摘要:
你所需要做的就是实现接口并添加所需的方法。现有的类不容易被改造来扩展一个新的抽象class.
抽象类提供基本实现的优势是什么?您可以为每个接口提供一个抽象的框架实现类。这结合了接口和抽象类的优点。框架实现提供了实现辅助,而不会强加抽象类作为类型定义时所强制的严格约束。例如,Collections Framework使用接口定义类型,并为每个接口提供一个框架实现。
发布于 2008-09-07 19:02:39
对接口进行编程提供了几个好处:
访问者类型模式所需的
https://stackoverflow.com/questions/48605
复制相似问题