本节书摘来自华章出版社《面向对象的思考过程(原书第4版)》一书中的第2章,第2.2节,[美] 马特·魏斯费尔德(Matt Weisfeld) 著黄博文 译更多章节内容可以访问云栖社区“华章计算机”公众号查看。
2.2 使用抽象思维设计接口
面向对象编程的主要优势之一是可以重用类。通常可以重用的类比具体的类的接口更加抽象。具体的接口可以是非常明确的,而抽象接口则更通用。简单来说,高层次的抽象接口比高度具体的接口更有用,大部分情况下如此,当然并非适用于所有情况。
完全可以编写一个非常有用的具体的类,而且这个类无法重用。这种情况经常出现,在某些情况下它也没什么错。然而,我们正在进行业务设计并且希望能得到面向对象提供的优势。所以我们的目标是设计抽象的可高度重用的类。为了做到这点,需要设计高度抽象的用户接口。我们可以创建一个出租车对象来演示抽象接口与具体接口的区别。该对象拥有一个诸如“送我去机场”接口可能比拥有一些独立的诸如“左转”、“右转”、“启动”、“停止”之类的接口更有用。因为正如图2-4所示,用户只想去机场。
当你从酒店出来时,把行李放到出租车后备厢,并坐上出租车,出租车司机会问你:“你想去哪里?”你回答:“请送我到机场。”(当然,这里假设这个城市只有一个机场。在芝加哥,你可能会说:“请送我到米德韦机场。”或者会说:“请送我到奥黑尔机场。”)。你可能自己都不知道如何到机场,甚至即使你知道,你也无须告诉司机什么时候转弯,转到哪个方向,如图2-5所示。作为乘客的你无需关心出租车司机的实际驾驶路径。(然而,如果司机故意绕路去机场,费用可能会有点问题。)
现在,抽象和重用的联系在哪里?请你自问这两个场景哪个更具重用性,是抽象的还是非抽象的?我们来更进一步简化问题,以下哪个短语更具重用性?是“送我去机场”还是“右转,右转,然后再左转,左转,左转”。显而易见,第一个短语更具重用性。你可以在任何城市中使用它,只要你钻进一个出租车并且想去机场。第二个短语只在特定的情况下可行。因此,抽象接口“送我去机场”更具通用性。可重用的面向对象设计针对芝加哥、纽约或克利夫兰市的实现是不同的。