参考答案:
【问题1】(8分)
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)。
在组合关系中,整体对象与部分对象具有同一的生存周期。当整体对象不存在时,部分对象也不存在。
而聚合关系中,对整体对象与部分对象没有这样的要求。