问答题 某公司的主要业务是出租图书和唱碟。由于业务需求,该公司委托希赛公司开发一套信息管理系统。该系统将记录所有的图书信息、唱碟信息、用户信息、用户租借信息等。希赛公司决定采用面向对象的分析和设计方法开发此系统。图1所示为某类图书或唱碟被借阅时应记录的信息,图2描述了系统定义的两个类Book和CD,分别表示图书和唱碟的信息。

图1 借阅时应记录的信息

问答题 经过进一步分析,设计人员决定定义一个类Items_on_loan,以表示类Book和CD的共有属性和方法。请采用图2中属性和方法的名称给出类Items_on_loan应该具有的属性和方法(注意,不同名称的属性和方法表示不同的含义,如CD中的composer与Book中的author无任何关系)。
【正确答案】属性:title, 方法:Reference Title。
【答案解析】[解析] 本题主要涉及类的设计、类之间的关系和顺序图。 在面向对象的程序设计当中,类的设计是非常重要的,类设计的合理性直接影响到整个系统的性能。 问题1要求考生写出类Items_on_loan的属性和方法,由于题目已经说明此类的属性和方法是Book类和CD类的公共属性和方法;又因为Book类和CD类中,不同名的属性、方法表示的含义不同,所以公共属性和方法就是同名属性和方法,因此Items on loan的属性有title,方法有Reference title。
问答题 为了记录每种图书或唱碟租借的历史记录,引入类CirculationHistoiy,类中存储的信息是图1中所表示的内容。请采用UML表示法将下列4个类之间的关系表示出来。
【正确答案】见图。 [*]
【答案解析】[解析] 问题2引入了CirculationHistory类,此类用于记录每种图书或光盘的租借记录。现要求CirculationHistory类、Book类、CD类及Items on loan类之间的关系,Items_on_loan是类Book和CD的公共部分,用面向对象的术语来说,类Items on loan是类Book和CD的父类,所以它们之间存在继承关系。 再看CirculationHistor),类和其他类的关系,CirculationHistory类只需要记录图书或唱碟的名称及借阅记录,而不需要其他详细资料,这样,CirculationHistory不必和Book与CD产生关系,只需要与Items on loan产生关系即可。由于CirculationHistory中除记录图书或唱片名称以外,还需要记录借出时间、归还时间及用户名,这些数据无法从Items_on_loan中获取。一个CirculationHistorv只包含一个Items_on_loan,存在1:1的关系,这说明Items_on_loan其实只是CirculationHistory的组成部分,但Items_on_loan可脱离CirculationHistory而独立存在,也就是说,一本图书或一张CD可以没有记录其借阅历史的CirculationHistory,但有记录其基本信息的。Items_on_loan,所以它们之间又存在聚集关系(而不是那种部分随整体销毁而销毁的组合关系)。综上所述,4个类的关系如图所示。 [*] 聚合关联中涉及重复度,当没有指定重复度时,默认重复度为1,那么,图中两个类CirculationHistory、Items_on_loan所在端的重复度都为1。
问答题 现需了解十大最畅销(借出次数最多)图书或唱碟。为此,引入TenPopulate类以存储所有十大畅销图书或CD的名称及其被借出的次数。如图3所示的顺序图描述了某类图书或唱碟被借出后成为十大畅销图书或唱碟时对象间的消息交互。系统在一次运行过程中,应有{{U}} {{U}} 3 {{/U}} {{/U}}个TenPopulate实例对象最合适,一个TenPopulate类实例对象最多需要和{{U}} {{U}} 4 {{/U}} {{/U}}个Items_on_loan实例对象交互。
【正确答案】(1)1。 (2)图书和唱碟种类数。
【答案解析】[解析] 题目中说“引入TemPopulate类以存储所有十大畅销图书或CD的名称及其被借出的次数”,可见TemPopulate类的功能是存储所有十大畅销图书或CD的名称及其被借出的次数。既然如此,系统在一次运行中只需要1个TenPopulate实例对象就可以了,因为它存储所有十大畅销图书或CD的名称及其被借出的次数。每当有图书或唱碟被借出时,都需要和TenPopulate类的对象发生交互,因此,当所有图书或CD都被借阅时,TenPopulate类实例对象需要跟所有这些Items_on_loan实例对象交互更新借出次数以评出十大最畅销图书或CD,一个TenPopulate类实例对象最多需要和“图书和唱碟种类总数”个Items_on_loan实例对象交互。