1、 软件工程案例分析之电梯问题 电梯问题 一、 开发场景 场景一: 名称:用户乘电梯上楼 参与执行者实例:电梯控制器、用户、按钮、电梯、电梯门、马达 前置条件:电梯设备正常通电,系统已开机。 后置条件:系统处于就绪状态。 事件流:1)用户在楼底层按动向上按钮,按动按钮事件将信号发送给电梯控制器,然后电梯控制器使电梯移动到底层,然后打开电梯门。 2)用户按梯层按钮,按动事件将发送给电梯控制器,电梯控制器等待超时,关闭门,控制马达向上升起并等待到达事件,当电梯到达用户请求的楼层后,电梯控制门打开,在动作序列中,电梯控制器与门对象和马达对象交互。 场景
2、二: 名称:用户乘电梯下楼 参与执行者实例:电梯控制器,用户,按钮,电梯,电梯门,马达; 前置条件:电梯设备正常通电,系统已开机 后置条件:系统处于就绪状态。 事件流:1)用户在除底层外的楼层,按动电梯等待室里的向下按钮召唤电梯并等待。电梯移至用户所在的楼层。 2)电梯停止在用户所在楼层后打开门,用户走进电梯并按下电梯内部控制面板上的底层按钮。 3)电梯门关闭,下降并停在底层,电梯打开,等待片刻,然后关门。 二、生成用例 用例名称:电梯控制器控制 参与执行者:电梯控制器、用户、按钮、电梯、马达、电梯门 前置条件:系统运行正常 主事件流: 系统判别按钮种类,是向
3、上或向下,或是楼层数字按钮,或是报警信号 如果按钮信号向上,则控制电梯向上运行,如果按钮信号向下,则控制电梯向下运行 依用户所按数字,向用户希望到达的楼层移动 若是报警信号,则向管理人员发出报警信号。 辅事件流: 马达依控制系统指示,向上或向下 后置条件: 传递异常信号后,管理人员置电梯“不可用”,否则电梯控制器控制电梯正常运行。 三、 用例活动图: 电梯控制系统 主动执行者 检测信号 按下按钮 [向上信号] [正常] 控制电梯向上 控制电梯向下 [异常] [向下信号] 发出报警信号
4、 处理异常 置电梯“可用” 置电梯“不可用” [正常] [异常] 四、 生成用例图 用户 管理人员 按钮 电梯 电梯门 马达 触发 控制器控制 五、 概念模型图 控制系统 (control system) 管理人员 (manager) 按钮 (button) l 向上按钮 l 向下按钮 l 报警按钮 l “可用按钮” l “不可用”按钮 电梯 操作:上行、下行 可用、不可用 电梯门 属性:门扇 操作:开门 关门 用户 (user) 异常事件
5、 l 请求冲突 l 用户报警 马达 操作:上移 下移 0…..* 六、 电梯问题的体系结构图 上/下移动 开/关电梯门 可用/不可用 用户 上/下按钮 报警按钮 管理人员 电梯控制器 电梯 press press 报警信号 处理异常 七、 用例实现图 将场景一及场景二合并起来,对应的用例实现图如下图所示,其中 边界类有: ² 底层:向上按钮接口类 ² 用户所在楼层:向下、向上按钮接口类 ² 用户请求的楼层:楼层数字按钮接口类 ² 底层:楼层数字按钮接口类 被动执行者有: Ø 电梯门 控制类有: Ø 控制器
6、 Ø 马达 1.1.11/2.1.11/3.1.11 /4.1.3arrive() 1.1.12/2.1.12/3.1.12 /4.1.4stop() 1.1.14/2.1.14/3.1.1/4.1.64timeout() 1.1.10/2.1.10/3.1.10/4.1.2movedown() 1.1.8/2.1.8/3.1.8 timeout() 1.1.2/2.1.2 /3.1.2.timeout( ) :用户 2.press 4.1goto(底层) 1.1.13/2.1.13/3.1.13/4.1.5open() 1.1.9/2.1.9/3.1.9 /4.1.1
7、colse() 1.1.7/2.1.7/3.1.7open() 1.1.6/2.1.6/3.1.6stop() 1.1.5/2.1.5/3.1.5Arrive() 1.1.4/2.1.4 /3.1.4movep() 1.1.1/2.1.1/3.1.1 open() 1.1 request(到某层) 3.1 request(向下) 3.press 2.1 goto floor 1.press 底层:向上按钮 用户请求:搂层数 的楼层 字按钮 用户所:向下 在楼层 按钮 底:楼层数 层 字按钮 电梯控制器 电梯门 :马达 1.1.3/2.1.3 /3.1.
8、3 close() 4.press 1.1.15/2.1.15/3.1.15/4.1.7close() 八、 对应的协作图 2.press 底层:楼层数字按钮 4.1goto(底层) 2.1goto floor 1.1Request( 向上) 3.1Request( 向下) Oipen()/close() Movedown() /moveup() /stop() 4.press :用户 底层:向上按钮 用户所在楼层:向下按钮 用户请求的楼层:楼层数字按钮 电梯控制器 :马达 :电梯门 Timeout()/arrive()
9、 九、 类图 0~n 管理人员 1 1 1 0~n 0~n 0~n 1 1~n 1~n 1 1 1~n 1~n 1 1 报警信号 异常事件 Ø 请求冲突 Ø 设置不可用 Ø 取消不可用 电梯控制器 电梯 按钮接口类 报警按钮接口类 报警按钮 按钮 用户 向上按钮 楼层号按钮 向下按钮 N 1 1 1 1~n 1 THANKS !!! 致力为企业和个人提供合同协议,策划案计划书,学习课件等等 打造全网一站式需求 欢迎您的下载,资料仅供参考 -可编辑修改-






