《数据结构与抽象:Java语言描述(原书第4版)》一1.3 使用ADT包
本节书摘来华章计算机《数据结构与抽象:Java语言描述(原书第4版)》一书中的第1章 ,第1.3节,[美]弗兰克M.卡拉诺(Frank M. Carrano) 蒂莫西M.亨利(Timothy M. Henry) 着 罗得岛大学 新英格兰理工学院 辛运帏 饶一梅 译 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1.3 使用ADT包
假定我们雇用一名程序员使用Java实现ADT包,给定到目前为止已有的接口和规格说明。如果假定这些规格说明已经足够清楚能让程序员完成相关的实现,那么我们可以在程序中使用这些ADT操作而不需要知道实现的细节。即,我们不需要知道程序员如何实现这个包,也能使用这个包。我们只需知道ADT包做什么就可以了。本节假定已经有了一个Java类Bag,它实现了程序清单1-1给出的Java接口BagInterface。简单的例子说明我们如何使用Bag。
在程序清单1-2的第13行,注意一旦我们选择了包中对象的数据类型(本例中是Item),这个数据类型就包含在接口名后面的尖括号中。还要注意类名后面的空尖括号。包中的所有项必须是这个数据类型或这个数据类型的子类型。编译程序强制我们遵守这条约定。如果是基本数据类型,则可以将对应的包装类的实例放入包中。例如,不是使用基本数据类型int的实例,而是使用包装类Integer的实例。
示例:在线购物。当在线购物时,你挑选的商品保存在购物车或购物袋内,直到你准备去结账为止。实现购物网站的程序可以使用类Bag来维护购物车。毕竟,你挑选的购买物品的次序是不重要的。程序清单1-2显示这样一个程序的简单示例。
为使示例简单,我们创建Item对象的数组来表示购物者挑选的商品。类Item可在本书的在线资源中找到,它定义了用来描述商品及价格的数据域,还定义了这些域的访问方法及toString方法。
初始时,我们使用Bag的默认构造方法创建Item对象的空包。注意,shoppingCart的数据类型是BagInterface。这个声明要求shoppingCart仅能调用声明在BagInterface中的方法。另外,我们可以用实现BagInterface的其他类来替换Bag,而不需要修改程序中后续的语句。
注意将挑选的商品添加到包中的循环,及结账时一次删除它们中的一个的循环。
自测题7 在前面的例子中,在结账过程中执行while循环,直到包是空的时为止。可用什么样的for语句来替换这个while语句?只根据shoppingCart的存在与否来写,而不是数组items。
示例:扑满。你或许有一个扑满、存钱罐,或者其他某个容器来存放你剩下的硬币。扑满装硬币,但并不组织它们。而扑满中肯定有重复的硬币。扑满好像一个包,但更简单,因为它仅有3个操作:可以将一个硬币添加到扑满中、删除一个(摇晃扑满,所以没办法控制哪个硬币掉下来),或者看看扑满是否为空。
假定你有表示硬币的类Coin,我们可以创建程序清单1-3中给出的类PiggyBank。PiggyBank对象将硬币保存在包中,即,保存在实现了接口BagInterface的类的实例中。PiggyBank的add、remove和isEmpty方法分别调用包方法来得到各自的结果。类PiggyBank是适配器类的一个示例。关于适配器类详见附录D。
程序清单1-3 扑满的类
程序清单1-4提供了类PiggyBank的主要示例。程序将一些硬币添加到扑满中,然后再删除所有的硬币。因为程序没有记录添加到扑满中的硬币,所以没办法控制删除哪个硬币。虽然输出的内容表示从扑满中拿走硬币的次序与它们放入扑满中的次序相反,但这个次序依赖于包的实现。我们在下一章将考虑这些实现。
注意,除了main方法外,程序定义了另一个方法addCoin。因为main是静态的且调用addCoin,所以addCoin也必须是静态的。方法addCoin接收的参数是一个Coin对象和一个PiggyBank对象。然后该方法将硬币添加到扑满中。
程序清单1-4 类PiggyBank的示例
注:方法可以改变作为参数传给它的对象的状态
将两个参数传给方法addCoin:一个硬币和一个扑满。这两个参数都是main方法中已存在的对象的引用。方法addCoin保存参数中这些引用的副本,你应该记得,它们的行为像局部变量。虽然addCoin不能改变引用,但因为它们已存在于main方法中,所以它能改变所指对象的状态。具体来说,它能通过向扑满中添加硬币来修改扑满(即PiggyBank对象)。记住,这个扑满只局部于main,且在addCoin的外面。
注:一旦在下一章实现了包类,你就能实际运行前一个程序清单中给出的程序。你只需要将类名Bag替换为下一章中的示例使用的一个类名即可。
自测题8 考虑程序清单1-4中的程序。在创建类PiggyBank的实例myBank后,假定将几个未知硬币添加到myBank中。写代码,从扑满中删除硬币,直到或者删除一分钱硬币,或者扑满为空时为止。
最后更新:2017-06-26 15:33:35
上一篇:
《数据结构与抽象:Java语言描述(原书第4版)》一1.4 像使用自动贩卖机一样使用ADT
下一篇:
Docker CE 镜像源站
可再生能源的颠覆威力
设计模式之Facade(外观)模式
失败成就伟大:谷歌的23个失败案例
java.text.format 将字符串“060503”转化为06:05:03或者将"20081002102030“转化为2008-10-02 10:00:30
自己把源码生成jar,在android项目中调用
java中泛型学习2之类型参数(T)
PostgreSQL 10.0 preview 功能增强 - 逻辑订阅端 控制参数解说
如何更改 Linux I/O 调度器来调整性能
阿里云发布POLARDB的背后,未来3年无自研数据库的云计算玩家将被淘汰
UbuntuEclipse颜色提示修改(WinXP窗口背景颜色修改)+快捷方式启动