状态图,或称状态机图,是统一建模语言(UML)用于建模系统的动态行为。它们展示了对象或系统如何在事件触发下从一个状态转换到另一个状态,因此非常适合用于反应式系统,如银行自动取款机(ATM)。本案例研究探讨了状态图如何表示ATM的行为,ATM是一种具有明确状态和事件驱动转换的常见现实系统。通过分析ATM的生命周期,我们将突出状态图的关键概念,包括状态、转换、动作、复合状态和无触发转换。本案例研究还展示了像Visual Paradigm这样的工具如何简化此类图表的创建。
以下是使用Visual Paradigm的状态机图建模编辑器创建的状态机图:

状态图通过定义以下内容来捕捉系统的行为:
状态:系统生命周期中的特定条件或状态(例如,“空闲”或“服务客户”)。
转换:由事件触发的状态间移动(例如,插入卡片)。
动作:在进入、退出或在状态间转换时执行的活动(例如,读取卡片)。
复合状态:包含子状态以实现分层建模的状态(例如,“服务客户”包含“客户认证”等子状态)。
初始状态和最终状态:系统行为的起始点和潜在的结束点。
无触发转换:无需显式事件的自动转换(例如,从自检状态转移到空闲状态)。
这些概念对于建模依赖于当前状态和外部刺激的系统至关重要,例如ATM。
银行ATM支持客户进行取现、存款和余额查询等交易。其行为是事件驱动的,具有因用户操作(如插入卡片、输入密码)或系统状态(如通过自检)而变化的明确状态。状态图是建模此类行为的有效工具,因为它能清晰定义ATM的状态、转换和动作,确保在设计、实现和维护过程中具有结构化的表达。
ATM在以下状态中运行:
已关闭
描述: ATM已关闭电源,无法与用户交互。这是系统启动前的初始状态。
关键特性: 在ATM开机之前,无法进行任何操作。
自检
描述: 开机后,ATM进入此状态以执行诊断测试,检查读卡器、键盘和现金出纳器等组件。
结果:
通过: ATM将进入“空闲”状态。
失败: ATM将进入“服务中断”状态。
关键特性: 此状态确保ATM在为客户提供服务前处于可运行状态。
服务中断
描述: 若自检失败或发生严重错误(例如现金出纳器故障),将进入此状态。ATM无法运行,需要维护。
关键特性: 作为最终状态,直到修复或重置为止。
空闲
描述: ATM已开机并处于运行状态,正在等待客户通过插入银行卡或信用卡来启动交易。
关键特性: 客户交互的主要等待状态。
服务客户
描述: 客户插入卡片时进入的复合状态。涵盖从身份验证到交易完成的所有客户交互。
进入动作: 读取卡片(ATM读取卡片信息)。
退出动作: 退卡(ATM释放卡片)。
子状态:
客户认证
ATM提示客户输入密码并进行验证。
如果密码错误,ATM可能会允许重试(例如最多三次尝试),然后再退卡。
选择交易
客户选择交易类型(例如:取款、存款、余额查询)。
交易
ATM处理所选交易(例如:发放现金、接收存款、显示余额)。
完成后,ATM返回“空闲”状态。
ATM根据事件或条件在状态间转换。主要转换包括:
|
转换 |
起始状态 |
目标状态 |
触发条件 |
动作 |
|---|---|---|---|---|
|
开机 |
关机 |
自检 |
ATM已开机 |
执行启动(初始化硬件) |
|
自检成功 |
自检 |
空闲 |
无(无触发) |
无 |
|
自检失败 |
自检 |
服务中断 |
测试失败 |
无 |
|
插卡 |
空闲 |
服务客户 |
客户插入卡片 |
读卡 |
|
认证成功 |
客户认证 |
选择交易 |
输入了有效的PIN码 |
无 |
|
认证失败(重试后) |
客户认证 |
空闲 |
无效PIN码(超过重试次数) |
退卡 |
|
已选择交易 |
选择交易 |
交易 |
客户选择交易 |
无 |
|
交易完成 |
交易 |
空闲 |
交易完成 |
退卡 |
|
取消 |
服务客户中的任意子状态 |
空闲 |
客户取消 |
退卡 |
此状态图展示了状态图的几个核心概念:
状态:ATM的行为被划分为不同的状态(例如:关机、空闲、服务客户),每种状态代表一种特定条件。
转换:如插卡或PIN验证等事件会触发状态变化,清晰地定义了系统的流程。
动作:进入动作(例如,读卡)和退出动作(例如,退卡)指定了状态变化期间的活动。
复合状态:“服务客户”状态包含子状态(客户认证、选择交易、交易),支持分层建模。
初始状态和最终状态:“关机”是初始状态,而“停用”则作为最终状态,直到维护完成为止。
无触发转换:如果自检通过,“自检”到“空闲”的转换会自动发生,无需显式事件。
状态图非常适合用于建模ATM,因为:
有限状态:ATM具有明确的状态集合(例如:空闲、服务客户),这些状态定义了其行为。
事件驱动行为:转换由用户操作(例如插入卡片、输入PIN)或系统条件(例如自检结果)触发。
层次结构:像“服务客户”这样的复合状态允许对复杂交互进行详细建模。
利益相关者的清晰性:该图提供了一个视觉表示,开发人员、设计师和利益相关者可以轻松理解,有助于系统设计和维护。
Visual Paradigm 是一款强大的 UML 建模工具,可简化状态图的创建。其功能包括:
拖放界面:轻松添加状态、转换和操作。
模拟工具:测试状态转换以验证图表的逻辑。
模板:使用为 ATM 等系统预构建的模板以加快建模速度。
代码生成:从图表生成代码骨架(例如 Java、C++)。
协作:实时团队编辑和评论,用于协作项目。
在 Visual Paradigm 中创建 ATM 状态图:
打开 Visual Paradigm 并选择图表 > 新建 > 状态机图.
使用拖放编辑器添加状态(例如,关机、自检、空闲)。
使用适当的触发条件绘制转换(例如,“开机”、“插入卡片”)。
定义操作(例如,readCard, ejectCard)用于进入、退出或转换。
使用模拟测试流程并确保准确性。
银行ATM状态图有效地展示了UML状态图如何模拟现实世界系统的行为。通过定义明确的状态、事件驱动的转换和操作,该图提供了ATM运行的结构化表示。这种方法增强了理解,促进了系统设计,并支持实现和维护。像Visual Paradigm这样的工具使得创建、测试和共享此类图表变得更加容易,确保了系统开发中的准确性和协作性。