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