列表

详情


阅读下列说明和图,回答问题1至问题3,将解答填入答题纸的对应栏内。
【说明】
    某网上药店允许顾客凭借医生开具的处方,通过网络在该药店购买处方上的药品。该网上药店的基本功能描述如下:
    (1)注册。顾客在买药之前,必须先在网上药店注册。注册过程中需填写顾客资料以及付款方式(信用卡或者支付宝账户)。此外顾客必须与药店签订一份授权协议书,授权药店可以向其医生确认处方的真伪。
    (2)登录。已经注册的顾客可以登录到网上药房购买药品。如果是没有注册的顾客,系统将拒绝其登录。
    (3)录入及提交处方。登录成功后,顾客按照“处方录入界面”显示的信息,填写开具处方的医生的信息以及处方上的药品信息。填写完成后,提交该处方。
    (4)验证处方。对于已经提交的处方(系统将其状态设置为“处方已提交”),其验证过程为:
  ①核实医生信息。如果医生信息不正确,该处方的状态被设置为“医生信息无效”,并取消这个处方的购买请求;如果医生信息是正确的,系统给该医生发送处方确认请求,并将处方状态修改为“审核中”。
  ②如果医生回复处方无效,系统取消处方,并将处方状态设置为“无效处方”。如果医生没有在7天内给出确认答复,系统也会取消处方,并将处方状态设置为“无法审核”。
  ③如果医生在7天内给出了确认答复,该处方的状态被修改为“准许付款”。
 系统取消所有未通过验证的处方,并自动发送一封电子邮件给顾客,通知顾客处方被取消以及取消的原因。
  (5)对于通过验证的处方,系统自动计算药品的价格并邮寄药品给己经付款的顾客。
该网上药店采用面向对象方法开发,使用UML进行建模。系统的类图如图3-1所示。

【问题1】(8分)
根据说明中的描述,给出图3-1中缺少的C1~C5所对应的类名以及(1)~(6)处所对应的多重度。
【问题2】(4分)
图3-2给出了“处方”的部分状态图。根据说明中的描述,给出图3-2中缺少的S 1~S4所对应的状态名以及(7)~(10)处所对应的迁移(transition)名。

   


【问题3】(3分)

图3-1中的符号在UML中分别表示类和对象之间的哪两种关系?两者之间的区别是什么?

参考答案:

【问题1】(8分)

C1:付款方式                                                                  (1分)
C2:处方                                                                          (1分)
C3:信用卡                                                                      (1分)
C4:支付宝账户                                                              (1分)
C5:处方上的药品(或药品)                                      (1分)
【其中C3、C4位置可互换】
(1)1                                 (2)0..*                              (3)1
(4)1..*                             (5)0..*                              (6)1
(1)~(6)各0.5分
【问题2】(4分,各0.5分)
S1:审核中         S2:无法审核        S3:医生信息无效        S4:无效处方
(7)医生信息不正确                             (8)医生信息正确
(9)医生回复处方无效                         (10)医生没有在7天内给出确认答复
【其中S2/(9)和S4/(10)可成对互换,S1/(7)和S3/(8)可成对互换,】
【问题3】(3分)
表示组合(composition),表示聚合(aggregation)。(1分)
在组合关系中,整体对象与部分对象具有同一的生存周期。当整体对象不存在时,部分对象也不存在。(1分)
而聚合关系中,对整体对象与部分对象没有这样的要求。(1分)

详细解析:

本题考查面向对象开发相关知识,涉及UML类图以及类图设计时的设计模式。UML目前在面向对象软件开发中广泛使用,是面向对象软件开发考查的重要内容。
【问题1】
本问题考查类图。要完成这个题目我们需要根据题目的描述来进行,根据题目前面的描述,我们不难找出该系统中应包含的类有顾客、处方、信用卡、支付宝账户、核实医生、付款方式和药品等。在类图中已经给出了顾客和核实医生两个类。根据题目描述:顾客在买药之前,必须先在网上药店注册。注册过程中需填写顾客资料以及付款方式(信用卡或者支付宝账户)。此外顾客必须与药店签订一份授权协议书,授权药店可以向其医生确认处方的真伪。再结合类图,我们不难看出C2应该是处方,因为它与顾客和医生都有关系,那么根据类图也就知道C5是药品。另外也可以知道C1是支付方式,而C3和C4是从C1继承而来,那么很显然是题目中描述的两种付款方式,分别是信用卡和支付宝账户。
知道了C1到C5的类以后,要求他们之间的重复度,就变得容易了,由于一个顾客可以与0至多个处方联系,而一个处方可以包含一至多种药品(如果没有药品,那么处方就没有存在的必要了),另外一个医生可以验证多张处方,也可以不验证处方。因此,顾客与处方是1:0...*关系,处方与药品是1:1...*的关系,而医生与处方为1:0...*的关系。
【问题2】
    本问题考查状态图。状态图用来描述一个特定对象的所有可能状态及其引起状态转移的事件。根据题目意思,在提交处方后,就应该验证处方,验证处方的步骤,首先是验证医生信息,如果医生信息不正确,该处方的状态被设置为“医生信息无效”,并取消这个处方的购买请求,那么结合状态图,我们可以知道,S3应该为“医生信息无效”,而7是医生信息不正确;那么8就是另外一个分支,是医生信息正确,如果医生信息正确,系统给该医生发送处方确认请求,并将处方状态修改为“审核中”,因此S1状态是“审核中”那么8就是医生信息正确。接着进入描述中的第二步,如果医生回复处方无效,系统取消处方,并将处方状态设置为“无效处方”。如果医生没有在7天内给出确认答复,系统也会取消处方,并将处方状态设置为“无法审核”。
结合状态图,我们可以知道S2应该是“无法审核”状态,而S4就是“无效处方”状态。相应的9就是医生回复处方无效,10就是医生没有在7天内给出确认答复。
【问题3】
本问题考查聚合与组合这两种关系的联系与区别。
表示组合(composition),表示聚合(aggregation)。
在组合关系中,整体对象与部分对象具有同一的生存周期。当整体对象不存在时,部分对象也不存在。
而聚合关系中,对整体对象与部分对象没有这样的要求。

上一题