全国计算机技术与软件专业技术资格(水平)考试

欢迎访问软件考试网(www.hbsoft.net)

2006年上半年 软件设计师 上午试卷

欢迎访问软件考试网(www.hbsoft.net)

● 两个同符号的数相加或异符号的数相减,所得结果的符号位SF和进位标志CF进行  1  运算为1时,表示运算的结果产生溢出。

    1A.        B.                 C. 与非              D. 异或

 

● 若浮点数的阶码用移码表示,尾数用补码表示。两规格化浮点数相乘,最后对结果规格化时,右规的右移位数最多为  2  位。

   2A. 1        B. 2                 C. 尾数位数          D. 尾数位数-1

 


● 高速缓存Cache与主存间采用全相联地址映像方式,高速缓存的容量为4MB,分为4块,每块1MB,主存容量为256MB。若主存读写时间为30ns,高速缓存的读写时间为3ns,平均读写时间为3.27ns,则该高速缓存的命中率为3%。若地址变换表如下所示,则主存地址为8888888H时,高速缓存地址为4H

3A. 90         B. 95               C. 97                D. 99  

   4A. 488888     B. 388888           C. 288888            D.188888

 

● 若某计算机系统是由500个元器件构成的串联系统,且每个元器件的失效率均为107/H,在不考虑其他因素对可靠性的影响时,该计算机系统的平均故障间隔时间为     5  小时。欢迎访问软件考试网(www.hbsoft.net)

   5A. 2×104    B. 5×104                   C. 2×105            D. 5×105

 


● 某指令流水线由5段组成,各段所需要的时间如下图所示。

连续输入10条指令时的吞吐率为  6 

   6A. 10/70t  B. 10/49t         C. 10/35t          D. 10/30t

 

● 相对于DES算法而言,RSA算法7,因此,RSA 8

7A. 加密密钥和解密密钥是不相同的         B. 加密密钥和解密密钥是相同的

C. 加密速度比DES要高                   D. 解密速度比DES要高

8A. 更适用于对文件加密                   B. 保密性不如DES

C. 可用于对不同长度的消息生成消息摘要   D. 可以用于数字签名


● 驻留在多个网络设备上的程序在短时间内同时产生大量的请求消息冲击某Web服务器,导致该服务器不堪重负,无法正常响应其他合法用户的请求,这属于9欢迎访问软件考试网(www.hbsoft.net)

9A. 网上冲浪  B. 中间人攻击        C. DDoS攻击      D. MAC攻击

 

上海市标准化行政主管部门制定并发布的工业产品的安全、卫生要求的标准,在其行政区域内是10欢迎访问软件考试网(www.hbsoft.net)

10A. 强制性标准    B. 推荐性标准    C. 自愿性标准    D. 指导性标准

 

● 小王购买了一个“海之久”牌活动硬盘,而且该活动硬盘还包含有一项实用新型专利,那么,王享有 11欢迎访问软件考试网(www.hbsoft.net)

11A.“海之久”商标专用权                 B. 该盘的所有权

C. 该盘的实用新型专利权                D. 前三项权利之全部

 

MPC(Multimedia PC)PC的主要区别是增加了12

12A. 存储信息的实体                      B. 视频和音频信息的处理能力

C. 光驱和声卡                          D. 大容量的磁介质和光介质

 

● 人眼看到的任一彩色光都是亮度、色调和饱和度三个特性的综合效果,其中13反应颜色的种类。欢迎访问软件考试网(www.hbsoft.net)

13A. 色调     B. 饱和度            C. 灰度       D. 亮度

 

CD上声音的采样频率为44.1kHz,样本精度为16b/s,双声道立体声,那么其未经压缩的数据传输率为14欢迎访问软件考试网(www.hbsoft.net)

14A. 88.2 kb/s                    B. 705.6 kb/s             
C. 1411.2 kb/s                   D. 1536.0 kb/s

 

● 在软件项目管理中可以使用各种图形工具来辅助决策,下面对Gantt图的描述中, 不正确的是 15欢迎访问软件考试网(www.hbsoft.net)

15A. Gantt图表现各个活动的持续时间

     B. Gantt图表现了各个活动的起始时间

     C. Gantt图反映了各个活动之间的依赖关系

     D. Gantt图表现了完成各个活动的进度

 

● 耦合度描述了16欢迎访问软件考试网(www.hbsoft.net)

16A. 模块内各种元素结合的程度           

B. 模块内多个功能之间的接口

C. 模块之间公共数据的数量      

D. 模块之间相互关联的程度

 

● 内聚是一种指标,表示一个模块17

17A. 代码优化的程度        B. 代码功能的集中程度

C. 完成任务的及时程度    D. 为了与其他模块连接所要完成的工作量

 

● 在软件项目开发过程中,评估软件项目风险时,18与风险无关

18A. 高级管理人员是否正式承诺支持该项目

B. 开发人员和用户是否充分理解系统的需求

C. 最终用户是否同意部署已开发的系统

D. 开发需要的资金是否能按时到位

 

● 开发专家系统时,通过描述事实和规则由模式匹配得出结论,这种情况下适用的开发语言是 19 欢迎访问软件考试网(www.hbsoft.net)

19A. 面向对象语言   B. 函数式语言        C.过程式语言   D.逻辑式语言

 

● 高级程序设计语言中用于描述程序中的运算步骤、控制结构及数据传输的是  20  欢迎访问软件考试网(www.hbsoft.net)

20A. 语句           B. 语义              C. 语用       D. 语法

 

● 为了解决进程间的同步和互斥问题,通常采用一种称为21机制的方法。若系统中有5个进程共享若干个资源R,每个进程都需要4个资源R,那么使系统不发生死锁的资源R的最少数目是22欢迎访问软件考试网(www.hbsoft.net)

   21A. 调度           B. 信号量            C. 分派       D. 通讯

   22A. 20             B. 18                C. 16         D. 15

   

● 在UNIX操作系统中,把输入/输出设备看作是23

   23A. 普通文件       B. 目录文件          C. 索引文件   D. 特殊文件

   

● 某软盘有40个磁道,磁头从一个磁道移至另一个磁道需要5ms。文件在磁盘上非连续存放,逻辑上相邻数据块的平均距离为10个磁道,每块的旋转延迟时间及传输时间分别为100ms25ms,则读取一个100块的文件需要24时间。

24A. 17500ms        B. 15000ms           C. 5000ms     D. 25000ms

 

● 文件系统中,设立打开文件(Open)系统功能调用的基本操作是25

25A. 把文件信息从辅存读到内存           

B. 把文件的控制管理信息从辅存读到内存

C. 把磁盘的超级块从辅存读到内存  

D. 把文件的FAT表信息从辅存读到内存

 

最主要的软件质量度量指标有正确性、可维护性、完整性和可用性,下面关于这些质量指标的描述中正确的是26 

   26A. 软件维护的工作量比开发阶段的工作量小 

         B. 正确性用每千行代码的故障(fault)数来度量

         C. 软件完整性是指软件功能与需求符合的程度

         D. 可用性与用户的操作效率和用户对软件的主观评价有关

 

某工程计划图如下图所示,弧上的标记为作业编码及其需要的完成时间(天),作业E最迟应在第27天开始。欢迎访问软件考试网(www.hbsoft.net)

 

 

 

 

      

27A. 7              B. 9                 C. 12           D. 13

 

正式的技术评审FTR(Formal Technical Review)是软件工程师组织的软件质量保证活动,下面关于FTR指导原则中不正确的是28

   28A. 评审产品,而不是评审生产者的能力

         B. 要有严格的评审计划,并遵守日程安排

         C. 对评审中出现的问题要充分讨论,以求彻底解决

         D. 限制参与者人数,并要求评审会之前做好准备

 

两个小组独立地测试同一个程序,第一组发现25个错误,第二组发现30个错误,在两个小组发现的错误中有15个是共同的,那么可以估计程序中的错误总数是29 

29A. 25              B. 30                C. 50         D. 60

 

下面有关测试的说法正确的是30

30A. 测试人员应该在软件开发结束后开始介入

  B. 测试主要是软件开发人员的工作

     C. 要根据软件详细设计中设计的各种合理数据设计测试用例

     D. 严格按照测试计划进行,避免测试的随意性

 

在绘制数据流图时,应遵循父图与子图平衡的原则,所谓平衡是指31

31A. 父图和子图都不得改变数据流的性质

B. 子图不改变父图数据流的一致性

C. 父图的输入/输出数据流与子图的输入/输出数据流一致

D. 子图的输出数据流完全由父图的输入数据流确定

 

下图中的程序由ABCDE 5个模块组成,下表中描述了这些模块之间的接口,每一个接口有一个编号。此外,模块ADE都要引用一个专用数据区。那么AE之间耦合关系是32欢迎访问软件考试网(www.hbsoft.net)

编号

参数

返回值

1

数据项

数据项

2

数据项

数据项

3

功能码

4

列表

 

 

 

 

 

 

 

32A. 公共耦合       B. 数据耦合            C. 内容耦合        D. 无耦合

 

C++语言中,若类C中定义了一个方法int f(int a, int b),那么方法33不能与该方法同时存在于类C中。

33A. int f(int x, int y)          B. int f(float a, int b)

     C. float f(int x, float y)      D. int f(int x, float y)

 

已知3个类OPQ,类O中定义了一个私有方法F1、一个公有方法F2和一个受保护的方法F3;类P和类Q是类O的派生类,其继承方式如下所示:

class P : protected O {…};欢迎访问软件考试网(www.hbsoft.net)

class Q : public O {…};

关于方法F1的描述中正确的是34;关于方法F2的描述中正确的是35;关于方法F3的描述中正确的是36

34A. 方法F1无法被访问欢迎访问软件考试网(www.hbsoft.net)

     B. 只有在类O内才能访问方法F1

    C. 只有在类P内才能访问方法F1

     D. 只有在类Q内才能访问方法F1

35A. OPQ的对象都可以访问方法F2

     B. PQ的对象都可以访问方法F2

     C. OQ的对象都可以访问方法F2

     D. 只有在类P内才能访问方法F2

36A. OPQ的对象都可以访问方法F3

     B. OPQ的对象都不可以访问方法F3

     C. OQ的对象都可以访问方法F3

     D. PQ的对象都可以访问方法F3

 

在面向对象软件开发过程中,采用设计模式37

   37A. 允许在非面向对象程序设计语言中使用面向对象的概念

         B. 以复用成功的设计和体系结构

         C. 以减少设计过程创建的类的个数

         D. 以保证程序的运行速度达到最优值

 

    以下关于单身模式(Singleton)的描述中,正确的是38

   38A. 它描述了只有一个方法的类的集合

         B. 它能够保证一个类只产生一个唯一的实例

         C. 它描述了只有一个属性的类的集合

         D. 它能够保证一个类的方法只能被一个唯一的类调用

 

下列关于一个类的静态成员的描述中,不正确的是39

39A. 该类的对象共享其静态成员变量的值

B. 静态成员变量可被该类的所有方法访问

C. 该类的静态方法只能访问该类的静态成员变量

D. 该类的静态数据成员变量的值不可修改

 

MVC(模型/视图/控制器)模式中,视图部分描述的是40

   40A. 将应用问题域中包含的抽象领域知识呈现给用户的方式

         B. 应用问题域中所包含的抽象类

C. 用户界面对用户输入的响应方式

         D. 应用问题域中包含的抽象领域知识

 

对于如下所示的UML类图,正确的描述是41

41A. B的实例中包含了对类C的实例的引用

     B. A的实例中包含了对类B的实例的引用

     C. A的实例中包含了对类C的实例的引用

     D. B的实例中包含了对类A的实例的引用

 

● UML中关联的多重度是指42欢迎访问软件考试网(www.hbsoft.net)

42A. 一个类有多少个方法被另一个类调用

     B. 一个类的实例能够与另一个类的多少个实例相关联

     C. 一个类的某个方法被另一个类调用的次数

     D. 两个类所具有的相同的方法和属性

 

已知3个类ABC,其中类A由类B的一个实例和类C1个或多个实例构成。能够正确表示类ABC之间关系的UML类图是43

43A.                                                          B.

 

 

 

 

 

    C.                                                           D.

 

 

 

● 对于下面的文法G[S]44是其句子(从S出发开始推导)。

     G[S]S → M|(S,M)       M → P|MP            P → a|b|c|...|x|x|z

44A. ((a,f))  B. ((fac,bb),g)     C. (abc)             D. (c,(da))

 

● 与逆波兰式ab+-c*d-对应的中缀表达式是45

45A. a-b-c*d  B. -(a+b)* c-d      C. -a+b*c-d          D. (a+b)* (-c-d)

 

● 下面的C程序代码段在运行中会出现46错误

    int i = 0; 欢迎访问软件考试网(www.hbsoft.net)

    while (i < 10);

      { i = i + 1;} 欢迎访问软件考试网(www.hbsoft.net)

46A. 语法     B. 类型不匹配       C. 变量定义          D. 动态语义

 

    ● 设有关系RS如下所示,则关系代数表达式的结果集为47

关系R

 

关系S

A

B

C

 

B

D

a1

b1

c1

 

b1

d1

a1

b2

c1

 

b2

d1

a2

b2

c2

 

 

 

        (47)

A.

 

B.

 

C.

 

D.

A

 

A

 

A

C

 

A

C

a1

 

a1

 

a1

c1

 

a1

c1

a1

 

 

 

 

 

 

a2

c2


● 某数据库中有员工关系E、产品关系P、仓库关系W和库存关系I,其中:员工关系EemployeeID, name, department)中的属性为:员工编号,姓名,部门;产品关系PproductID, name, model, size, color)中的属性为:产品编号,产品名称,型号,尺寸,颜色;仓库关系WwarehouseID, name, address, employeeID)中的属性为:仓库编号,仓库名称,地址,负责人编号;库存关系IwarehouseID, productID, quantity)中的属性为仓库编号,产品编号和产品数量。
a.
若要求仓库关系的负责人引用员工关系的员工编号,员工关系E的员工编号、仓库关系W的仓库编号和产品关系P的产品编号不能为空且惟一标识一个记录,并且仓库的地址不能为空,则依次要满足的完整性约束是48

   48 A. 实体完整性、参照完整性、用户定义完整性

B. 参照完整性、实体完整性、用户定义完整性

   C. 用户定义完整性、实体完整性、参照完整性

   D. 实体完整性、用户定义完整性、参照完整性

b. 若需得到每种产品的名称和该产品的总库存量,则对应的查询语句为:

SELELCT name, SUM(quantity)

FROM P, I

WHERE  49 欢迎访问软件考试网(www.hbsoft.net)

   49 A.  P.productID=I.productID;     

   B.  P.productID=I.productID ORDER BY name;

C.  P.productID=I.productID GROUP BY name;

   D.  P.productID=I.productID GROUP BY name, quantity;

       c. 若需得到在所有仓库中都存在的产品的名称,则对应的查询语句为:

    SELECT name FROM P

    WHERE  50欢迎访问软件考试网(www.hbsoft.net)

        (SELECT * FROM W

WHERE NOT EXISTS

(SELECT * FROM I

WHERE P.productID=I.productID AND W.warehouseID=I.warehouseID))

   50A. EXISTS         B. NOT EXISTS        C. IN                D. NOT IN 

  

    ● 对事务回滚的正确描述是51欢迎访问软件考试网(www.hbsoft.net)

51A. 将该事务对数据库的修改进行恢复

B. 将事务对数据库的更新写入硬盘

        C. 跳转到事务程序的开头重新执行

D. 将事务中修改的变量值恢复到事务开始时的初值

 

● 拓扑序列是无环有向图中所有顶点的一个线性序列,图中任意路径中的各个顶点在该图的拓扑序列中保持先后关系,  52  下图所示有向图的一个拓扑序列。

        

52A. 1 2 3 4 5 6 7                B. 1 5 2 6 3 7 4    
C. 5 1 2 6 3 4 7                 D. 5 1 2 3 7 6 4

 

● 为便于存储和处理一般树结构形式的信息,常采用孩子-兄弟表示法将其转换成二叉树(左子关系表示父子、右子关系表示兄弟),与下图所示的树对应的二叉树是53欢迎访问软件考试网(www.hbsoft.net)

          

53

● 给定一个有n个元素的有序线性表。若采用顺序存储结构,则在等概率前提下,删除其中的一个元素平均需要移动 54个元素。

54A.          B.                C.            D. 1

 

● 在平衡二叉树中, 55欢迎访问软件考试网(www.hbsoft.net)

55A. 任意结点的左、右子树结点数目相同

       B. 任意结点的左、右子树高度相同

       C. 任意结点的左右子树高度之差的绝对值不大于1

       D. 不存在度为1的结点

 

56存储结构中,数据结构中元素的存储地址与其关键字之间存在某种映射关系欢迎访问软件考试网(www.hbsoft.net)

56A. 顺序Sequence               B. 链表Link   

C. 索引Index                  D. 散列(Hash

 

    ● 对于求取两个长度为n的字符串的最长公共子序列(LCS)问题,利用57 策略可以有效地避免子串最长公共子序列的重复计算,得到时间复杂度为O(n2)的正确算法。串<1,0,0,1,0,1,0,1><0,1,0,1,1,0,1,1>的最长公共子序列的长度为58

57A. 分治           B. 贪心       C. 动态规划          D. 分支-限界

58A. 3              B. 4          C. 5                 D. 6

 

● 设某算法的计算时间可用递推关系式T(n) = 2T(n/2) + n 表示,则该算法的时间复杂度为59欢迎访问软件考试网(www.hbsoft.net)

59A.        B.   C.             D.

 

 60在其最好情况下的算法时间复杂度为欢迎访问软件考试网(www.hbsoft.net)

60A. 插入排序        B. 归并排序   C. 快速排序          D. 堆排序

 

● 与多模光纤相比较,单模光纤具有 61等特点。

61A. 高的传输率、较长的传输距离、较高的成本

B. 较低的传输率、较短的传输距离、较高的成本

C. 较高的传输率、较短的传输距离、较低的成本

D. 较低的传输率、较长的传输距离、较低的成本

 

CDMA系统中使用的多路复用技术是62我国自行研制的移动通信3G标准是63欢迎访问软件考试网(www.hbsoft.net)

62A. 时分多路       B. 波分多路   C. 码分多址          D. 空分多址

63A. TDSCDMA                    B. WCDMA

      C. CDMA2000                     D. GPRS      

 

● “<title style="italic">science</title>”是XML中一个元素的定义,其中元素的内容是 64欢迎访问软件考试网(www.hbsoft.net)

64A. title          B. style      C. italic            D. science

 

● 某校园网用户无法访问外部站点210.102.58.74,管理人员在Windows操作系统下可以使用65判断故障发生在校园网内还是校园网外。

65A. ping 210.102.58.74            B. tracert 210.102.58.74

C. netstat 210.102.58.74         D. arp 210.102.58.74

 

Originally introduced by Netscape Communications,  66  are a general mechanism which HTTP Server side applications, such as CGI  67 , can use to both store and retrieve information on the HTTP  68  side of the connection. Basically, Cookies can be used to compensate for the  69  nature of HTTP. The addition of a simple, persistent, client-side state significantly extends the capabilities of WWW-based  70 .

66A. Browsers       B. Cookies    C. Connections       D. Scripts

67A. graphics       B. processes  C. scripts           D. texts

68A. Client         B. Editor     C. Creator           D. Server

69A. fixed          B. flexible   C. stable            D. stateless

70A. programs      B. applications                                   C. frameworks      D. constrains

 

WebSQL is a SQL-like  71  language for extracting information from the web. Its capabilities for performing navigation of web  72  make it a useful tool for automating several web-related tasks that require the systematic processing of either all the links in a    73 , all the pages that can be reached from a given URL through  74  that match a pattern, or a combination of both. WebSQL also provides transparent access to index servers that can be queried via the Common  75  Interface.

71A. query          B. transaction                                            C. communication  D. programming

72A. browsers       B. servers      C. hypertexts      D. clients

73A. hypertext      B. page       C. protocol   D. operation

74A. paths          B. chips      C. tools      D. directories

75A. Router         B. Device     C. Computer   D. Gateway

 

 

下午试卷

 

试题一15欢迎访问软件考试网(www.hbsoft.net)

阅读下列说明以及数据流图,回答问题1、问题2和问题3,将解答填入答题纸的对应栏内。

【说明】欢迎访问软件考试网(www.hbsoft.net)

某学校建立了一个网上作业提交与管理系统,基本功能描述如下:

(1) 帐号和密码。任课老师用帐号和密码登录系统后,提交所有选课学生的名单。系统自动为每个选课学生创建登录系统的帐号和密码。

(2) 作业提交。学生使用帐号和密码登录系统后,可以向系统申请所选课程的作业。系统首先检查学生的当前状态,如果该学生还没有做过作业,则从数据库服务器申请一份作业。若申请成功,则显示需要完成的作业。学生需在线完成作业,单击“提交”按钮上交作业。

(3) 在线批阅。系统自动在线批改作业,显示作业成绩,并将该成绩记录在作业成绩统计文件中。

【问题13分)欢迎访问软件考试网(www.hbsoft.net)

如果将数据库服务器(记为DB)作为一个外部实体,那么在绘制该系统的数据流图时,还应有哪些外部实体和数据存储?

【问题27分)欢迎访问软件考试网(www.hbsoft.net)

根据说明结合问题1的解答,指出在该系统的顶层数据流图中应有哪些数据流。请采用说明中的词汇给出这些数据流的起点、终点以及数据流名称,下表给出了数据流的部分信息,请填充空缺处。

序号

起点

终点

数据流名称

1

   (1)  

网上作业提交与管理系统

作业申请

2

   (2)  

网上作业提交与管理系统

提交的作业

3

网上作业提交与管理系统

   (3)  

需完成的作业

4

网上作业提交与管理系统

   (4)  

   (5)  

5

网上作业提交与管理系统

   (6)  

作业申请

6

网上作业提交与管理系统

   (7)  

   (8)  

7

   (9)  

网上作业提交与管理系统

选课学生名单

8

   (10)  

网上作业提交与管理系统

   (11)  

9

   (12)  

网上作业提交与管理系统

帐号和密码

10

   (13)  

网上作业提交与管理系统

帐号和密码

 


【问题35分)欢迎访问软件考试网(www.hbsoft.net)

根据数据流图的设计原则,阅读下图所示的数据流图,找出其中的错误之处。

 

试题二(15) 欢迎访问软件考试网(www.hbsoft.net)

阅读下列说明以及UML类图,回答问题1、问题2和问题3,将解答填入答题纸的对应栏内。

【说明】

某客户信息管理系统中保存着两类客户的信息:

(1) 个人客户。对于这类客户,系统保存了其客户标识(由系统生成)和基本信息(包括姓名、住宅电话和email)。

(2) 集团客户。集团客户可以创建和管理自己的若干名联系人。对于这类客户,系统除了保存其客户标识(由系统生成)之外,也保存了其联系人的信息。联系人的信息包括姓名、住宅电话、email、办公电话以及职位。

该系统除了可以保存客户信息之外,还具有以下功能:

(1) 向系统中添加客户(addCustomer);

(2) 根据给定的客户标识,在系统中查找该客户(getCustomer);

(3) 根据给定的客户标识,从系统中删除该客户(removeCustomer);

(4) 创建新的联系人(addContact);

(5) 在系统中查找指定的联系人(getContact);

(6) 从系统中删除指定的联系人(removeContact)。

该系统采用面向对象方法进行开发。在面向对象分析阶段,根据上述描述,得到如表2-1所示的类。欢迎访问软件考试网(www.hbsoft.net)

表2-1

类名

说明

CustomerInformationSystem

客户信息管理系统

IndividualCustomer

个人客户

InstitutionalCustomer

集团客户

Contact

联系人

 

描述该客户信息管理系统的UML类图如图2-1所示。欢迎访问软件考试网(www.hbsoft.net)


 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


图2-1  客户信息管理系统的UML类图

【问题1】(3分)

请使用说明中的术语,给出图2-1中类Customer和类Person的属性。

【问题2】(6分)

识别关联的多重度是面向对象建模过程中的一个重要步骤。根据说明中给出的描述,完成图中的(1)~(6)

【问题36分)

根据说明中的叙述,抽象出如表2-2所示的方法,请指出图2-1中的类CustomerInformationSystemInstitutionalCustomer应分别具有其中的哪些方法。

表2-2

功能描述

方法名

向系统中添加客户

addCustomer

根据给定的客户标识,在系统中查找该客户

getCustomer

根据给定的客户标识,从系统中删除该客户

removeCustomer

创建新的联系人

addContact

在系统中查找指定的联系人

getContact

从系统中删除指定的联系人

removeContact


试题三(15分)

阅读下列说明,回答问题1、问题2和问题3,将解答填入答题纸的对应栏内。

【说明】

某单位资料室需要建立一个图书管理系统,初步的需求分析结果如下:

(1) 资料室有图书管理员若干名,他们负责已购入图书的编目和借还工作,每名图书管理员的信息包括工号和姓名;

(2) 读者可在阅览室读书,也可通过图书流通室借还图书,读者信息包括读者ID、姓名、电话和Email,系统为不同读者生成不同的读者ID

(3) 每部书在系统中对应惟一的一条图书在版编目数据(CIP,以下简称书目),书目的基本信息包括ISBN号、书名、作者、出版商、出版年月,以及本资料室拥有该书的册数(以下简称册数),不同书目的ISBN号不相同;

(4) 资料室对于同一书目的图书可拥有多册(本),图书信息包括图书IDISBN号、存放位置、当前状态,每一本书在系统中被赋予惟一的图书ID

(5) 一名读者最多只能借阅十本图书,且每本图书最多只能借两个月,读者借书时需由图书管理员登记读者ID、所借图书ID、借阅时间和应还时间,读者还书时图书管理员在对应的借书信息中记录归还时间;

(6) 当某书目的可借出图书的数量为零时,读者可以对其进行预约登记,即记录读者ID、需要借阅的图书的ISBN号、预约时间。

某书目的信息如表3-1所示,与该书目对应的图书信息如表3-2所示。

3-1  书目信息

 

 

出版商

ISBN

出版年月

册数

经办人

《数据结构》

严蔚敏

吴伟民

清华大学出版社

ISBN7-302-02368-9

1997.4

4

01

3-2  图书信息

图书ID

ISBN

存放位置

状态

经办人

C832.1

ISBN7-302-02368-9

图书流通室

已借出

01

C832.2

ISBN7-302-02368-9

图书阅览室

不外借

01

C832.3

ISBN7-302-02368-9

图书流通室

未借出

01

C832.4

ISBN7-302-02368-9

图书流通室

已预约

01

系统的主要业务处理如下:

(1) 入库管理:图书购进入库时,管理员查询本资料室的书目信息,若该书的书目尚未建立,则由管理员编写该书的书目信息并录入系统,然后编写并录入图书信息;否则,修改该书目的册数,然后编写并录入图书信息,对于进入流通室的书,其初始状态为“未借出”,而送入阅览室的书的状态始终为“不外借”。

(2) 借书管理:读者借书时,若有,则由管理员为该读者办理借书手续,并记录该读者的借书信息,同时借出图书的状态修改为“已借出”。

(3) 预约管理:若图书流通室没有读者要借的书,则可为该读者建立预约登记,需要记录读者ID、书的ISBN号、预约时间和预约期限(最长为10天)。一旦其他读者归还这种书,就自动通知该预约读者。系统将自动清除超出预约期限的预约记录并修改相关信息。

(4) 还书管理:读者还书时,则记录相应借还信息中的“归还时间”,对于超期归还者,系统自动计算罚金(具体的计算过程此处省略)。系统同时自动查询预约登记表,若存在其他读者预约该书的记录,则将该图书的状态修改为“已预约”,并将该图书ID写入相应的预约记录中(系统在清除超出预约期限的记录时解除该图书的“已预约”状态);否则,将该图书的状态修改为“未借出”。

(5) 通知处理:对于已到期且未归还的图书,系统通过Email自动通知读者;若读者预约的书已到,系统则自动通过Email通知该读者来办理借书手续。

【问题1】(4分)

根据以上说明设计的实体联系图如图3-1所示,请指出读者与图书、书目与读者、书目与图书之间的联系类型。

图3-1  图书管理系统的实体联系图

【问题2】(4分)

       该图书管理系统的主要关系模式如下,请补充“借还记录”和“预约登记”关系中的空缺。

管理员(工号,姓名)

读者      (读者ID,姓名,电话,Email)

书目      (ISBN号,书名,作者,出版商,出版年月,册数,经办人)

图书(图书IDISBN号,存放位置,状态,经办人)

借还记录(      (a)       ,借出时间,应还时间,归还时间)

预约登记(      (b)       ,预约时间,预约期限,图书ID)

注:时间格式为“年..日 时::

【问题3】(7分)
请指出问题2中给出的读者、书目关系模式的主键,以及图书、借还记录和预约登记关系模式的主键和外键。


试题四(15)

阅读以下说明,回答问题1、问题2和问题3,将解答填入答题纸的对应栏内。

【说明】

       某单位正在使用一套C/S模式的应用软件系统,现在需要升级为B/S应用模式,但需要保持业务的连续性。开发人员提出用Web Service作为中间层的接口进行开发。

【问题1】(6分)

    请用120字以内文字,从业务的继承性、升级成本(时间、工作量)和扩展性三个方面简要说明开发人员所提方案的优点。

【问题23分)

      Web Service的三个基本技术是WSDLSOAPUDDI,它们都是以XML为基础定义的。请120字以内文字,简要说明WSDLSOAPUDDI的作用

【问题36分)

      服务注册中心、服务提供者和服务请求者之间的交互和操作构成了Web Service的体系结构,如图4-1所示。请180字以内文字,说明这三者的主要功能及其交互过程。

4-1  Web Service的工作模式


试题五(15)

阅读下列说明、图和C代码,将应填入n处的字句写在答题纸的对应栏内。

【说明5-1

B树是一种多叉平衡查找树。一棵m阶的B树,或为空树,或为满足下列特性的m叉树:

树中每个结点至多有m棵子树;

若根结点不是叶子结点,则它至少有两棵子树;

除根之外的所有非叶子结点至少有棵子树;

所有的非叶子结点中包含下列数据信息

    (nA0K1A1K2A2KnAn)

其中:Ki(i=12……n)为关键字,且Ki<Ki+1(i=12n-1)Ai(i=01n)为指向子树根结点的指针,且指针Ai-1所指子树中所有结点的关键字均小于KiAi+1所指子树中所有结点的关键字均大于Kin为结点中关键字的数目。

所有的叶子结点都出现在同一层次上,并且不带信息(可以看作是外部结点或查找失败的结点,实际上这些结点不存在,指向这些结点的指针为空)。

例如,一棵4B树如图5-1所示(结点中关键字的数目省略)。

5-1  4B树示例

B树的阶Mbool类型、关键字类型及B树结点的定义如下:

#define   M   4                             /*B树的阶*/

typedef enum {FALSE = 0,TRUE = 1} bool;

typedef int ElemKeyType;

typedef struct BTreeNode{     

          int numkeys;                 /*结点中关键字的数目*/

          struct BTreeNode *parent ;   /*指向父结点的指针,树根的父结点指针为空*/  

          struct BTreeNode  *A[M];     /*指向子树结点的指针数组*/

       ElemKeyType  K[M];           /*存储关键字的数组,K[0]闲置不用*/

}BTreeNode;

函数SearchBtree(BTreeNode* root, ElemKeyType akey, BTreeNode **ptr)的功能是:在给定的一棵MB树中查找关键字akey所在结点,若找到则返回TRUE,否则返回FALSE。其中,root是指向该MB树根结点的指针,参数ptr返回akey所在结点的指针,若akey不在该B树中,则ptr返回查找失败时空指针所在结点的指针。例如,在图5-1所示的4B树中查找关键字25时,ptr返回指向结点e的指针。

注:在结点中查找关键字akey时采用二分法。

【函数5-1

bool SearchBtree(BTreeNode* root, ElemKeyType akey, BTreeNode **ptr)

{

   int  lw, hi, mid;         

   BTreeNode *p = root;

   *ptr = NULL;

   while ( p ) {

      lw = 1;    hi =    (1)   ;

      while (lw <= hi) {

             mid = (lw + hi) / 2;

          if (p -> K[mid] == akey){

             *ptr = p;

return TRUE;

          }

          else

             if (   (2)   ) 

hi = mid - 1;

             else

           lw = mid + 1;

      }

      *ptr = p;    

 p =    (3)   ;

   }

   return FALSE;

}


【说明5-2

MB树中插入一个关键字时,首先在最接近外部结点的某个非叶子结点中增加一个关键字,若该结点中关键字的个数不超过M-1,则完成插入;否则,要进行结点的分裂处理。所谓分裂,就是把结点中处于中间位置上的关键字取出来并插入其父结点中,然后以该关键字为分界线,把原结点分成两个结点。分裂过程可能会一直持续到树根,若树根结点也需要分裂,则整棵树的高度增1

例如,在图5-1所示的B树中插入关键字25时,需将其插入结点e中,由于e中已经有3个关键字,因此将关键字24插入结点e的父结点b,并以24为分界线将结点e分裂为e1e2两个结点,结果如图5-2所示。

5-2  在图5-1所示的4B树中插入关键字25后的B

函数Isgrowing(BTreeNode* root, ElemKeyType akey)的功能是:判断在给定的MB树中插入关键字akey后,该B树的高度是否增加,若增加则返回TRUE,否则返回FALSE。其中,root是指向该MB树根结点的指针。

在函数Isgrowing,首先调用函数SearchBtree(即函数5-1查找关键字akey是否在给定的MB树中,若在则返回FALSE(表明无需插入关键字akey,树的高度不会增加);否则,通过判断结点中关键字的数目考察插入关键字akey后该B树的高度是否增加。

【函数5-2

bool Isgrowing(BTreeNode* root, ElemKeyType akey)

{      BTreeNode *t, *f;

    if ( !SearchBtree(   (4)   ) ) {

       t = f;

       while (   (5)   ) {

           t = t -> parent;

       }

       if ( !t )

         return TRUE;

    }

    return FALSE;

}


试题六(15分)

阅读下列说明、图和C++代码,将应填入n处的字句写在答题纸的对应栏内。

【说明】

某订单管理系统的部分UML类图如图6-1所示。

 

 

 

 

 

 

 

 

 


6-1  订单管理系统的部分UML类图

6-1中,Product表示产品,ProductList表示产品目录,Order表示产品订单,OrderItem表示产品订单中的一个条目,OrderList表示订单列表,SalesSystem提供订单管理系统的操作接口。

请完善Order的成员函数getOrderedAmount()和类SalesSystemstatistic()方法,各个类的属性及部分方法定义参见下面的C++代码。

C++代码】

class Product {                                                      //产品类

private:     

     string pid;                                              //产品识别码

        string description;                            //产品描述

       double price;                            //产品单价

public:

        void setProductPrice(double price);     //设置产品单价

        string getProductId();                                //获取产品识别码

        string getProductDescription ();        //获取产品描述

        double getProductPrice();                      //获取产品单价

       //其他成员省略

};

 

class ProductList {                                           //产品列表类

private:

       vector <Product> products;

public:

    ProductList();

  Product getProductByIndex(int i);  //获得产品列表中的第i件产品

    void addProduct(Product t);                        //在产品列表中加入一件产品

    Product * getProductByID(string pid);   //获得识别码为pid的产品指针

       unsigned int getProductAmount();         //获得产品列表中的产品数量

};

 

class OrderItem {                                             //订单条目类

private:

        Product *productPtr;                      //指向被定购产品的指针

        int quantity;                                         //定购数量

public:

        OrderItem (Product *,int);

     Product * getProductptr ();                //获取指向被定购产品的指针

     int getQuantity ();                               //获取被定购产品的数量

};

 

class Order {                                   //订单类

private:

        unsigned int orderid;                                 //订单识别号

        vector<OrderItem> items;                //订单内容(订单项)

public:

        Order(unsigned int orderid);

     //获得识别码为tid的产品在当前订单中被定购的数量

int getOrderedAmount(string tid);  

     void additem(Product *productPtr,unsigned int n);//在订单中增加一个订单项

//其他成员省略

};

 

class OrderList {                                             //订单列表类

private:

       vector<Order> orders;

public:

       OrderList();

    //Begin()返回指向订单列表第一个元素的迭代器(指针)

    virtual vector<Order>::iterator OrderList::Begin();

    //End()返回指向订单列表最后一个元素之后的迭代器(指向一个不存在的元素)

       virtual vector<Order>::iterator OrderList::End();

    void addOrder(Order t);              //在订单列表中加入一份订单

//其他成员省略

};

 

 

class SalesSystem{

private:

       ProductList catalog; //产品目录

       OrderList sales;           //订单列表

public:

       SalesSystem();

       void statistic();          //统计所有产品的定购情况

    //其他成员省略

};

 

//在订单中查找识别码为tid的产品的定购数量,若该产品没有被定购,则返回0

int Order::getOrderedAmount(string tid)

{      for (int k = 0; k < items.size(); k++){

              if (    (1)    == tid)

          return    (2)   ;

       }

    return 0;

}

 

// 方法statistic()依次统计产品目录中每个产品的订购总量,并打印输出

// 每个产品的识别码、描述、订购总量和订购金额

void SalesSystem::statistic()

{      unsigned int k, t, ordered_qty = 0;

    vector<Order>::iterator it;   Product p;

       cout << "产品识别码\t描述\t\t定购数量\t金额" << endl;

   

       for (k = 0; k < catalog.getProductAmount(); k++){//遍历产品列表

              p =    (3)   ;       //从产品列表取得一件产品信息存入变量p

           ordered_qty = 0;

        //通过迭代器变量it遍历订单列表中的每一份订单

              for (it = sales.Begin();   (4)   ; it++) {

//根据产品识别码获得产品p在当前订单中被定购的数量

        t =    (5)   (p.getProductId());

                  ordered_qty += t;

              }

              cout << p.getProductId() << "\t\t"<< p.getProductDescription() << "\t\t";

              cout <<ordered_qty << "\t\t" << p.getProductPrice() * ordered_qty << endl;

      }

}

试题七15分)

阅读下列说明、图以及Java程序将应填入n处的字句写在答题纸的对应栏内。

说明

某订单管理系统的部分UML类图如图7-1所示。

 

 

 

 

 

 

7-1  订单管理系统的部分UML类图

7-1中,Product表示产品,ProductList表示所销售产品的列表,Order表示产品订单,OrderItem表示产品订单中的一个条目,OrderList表示订单列表,SalesSystem提供订单管理系统的操作接口。各个类的部分属性和方法说明如表7-1所示。

7-1

成员

说明

ProductList

ArrayList<Product>  products

 

Product

String code

产品编号

String description

产品描述

double price

产品单价

Boolean equals(Object object)

若两个产品相同则返回true,否则返回false

OrderItem

Product product

订单项中的产品

int quantity

产品的订购数量

Product  getProduct()

获取订单项中的产品

Order

ArrayList<OrderItem>  items

订单中包含的订单项

OrderList

ArrayList<Order> orders

订单

void addOrder(Order order)

向订单列表中添加新订单

int getNumberOfOrders()

获取订单列表中的订单总数

SalesSystem

ProductList catalog

产品目录

OrderList sales

订单列表

void statistic()

依次统计产品目录中每个产品的订购总量,并打印出每个产品的编号、说明、订购总量和订购金额

   

可以使用类java.util.ArrayList<E>来实现对象的聚集关系,如图7-1OrderListOrder之间的聚集关系。

for-each循环提供了一种遍历对象集合的简单方法。在for-each循环中,可以指定需要遍历的对象集合以及用来接收集合中每个元素的变量,其语法如下:

for( 用来接收集合中元素的变量 : 需要遍历的对象集合)

如果要使用for-each循环来遍历对象集合,那么包含该对象集合的类必须实现接口java.util.Iterable<T>

Java程序7-1Java程序7-2分别给出了类OrderList和方法statisticJava代码。

 

Java程序7-1

import java.util.*;

public class OrderList    (1)   { 

       private ArrayList<Order> orders;

       public OrderList() {

              this.orders = new ArrayList<Order>();

       }     

       public void addOrder(Order order) {     

              this.orders.add(order);

       }

       public Iterator<Order> iterator() {     

              return    (2)  ;

       }

       public int getNumberOfOrders() { 

              return this.orders.size();

       }

}

 

Java程序7-2

import java.util.*;

public class SalesSystem {

private ProductList catalog;

private OrderList sales;

private static PrintWriter  stdOut = new  PrintWriter(System.out, true);

public void statistic() {

    for (Product product :   (3)   ) {

int number = 0;

     for (Order order :   (4)   ) {

         for (   (5)   : order) {

            if (product.equals(item.getProduct()))

                number += item.getQuantity();

         }

     }

     stdOut.println(product.getCode() + "  "

                              + product.getDescription() + "  "

                              + number + "  " + number * product.getPrice());

}

}

// 其余的方法未列出

}