news 2026/2/2 11:37:11

活动图用于工作流的状态机和业务对象状态机

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
活动图用于工作流的状态机和业务对象状态机

核心区别:

维度系统级工作流状态机业务对象状态机
建模对象一个业务流程工作流实例一个业务实体(如Order、Payment)的实例
状态定义流程的阶段活动(如“正在验证”、“正在执行”)实体的业务状态(如“待支付”、“已发货”)
关注焦点控制与协调:哪个活动该在何时执行,流程如何推进数据与规则:实体在业务规则下允许如何变化
转换触发子活动完成外部事件业务对象状态达到某条件触发具体业务操作(如pay()ship())触发
生命周期相对较短,与单个流程实例的执行时间一致相对较长,与实体的业务存在时间一致(如订单从创建到完成可能数天)

具体例子说明

以一个简化的“在线订单履约”流程为例:

1. 系统级工作流状态机(用于调度)

  • 状态(阶段)

    • OrderReceived:订单已接收,初始阶段。

    • PaymentVerification:支付验证阶段。

    • InventoryReservation:库存预留阶段。

    • ShippingArrangement:物流安排阶段。

    • ProcessCompleted:流程完成。

  • 转换触发

    • OrderReceivedPaymentVerification:当订单对象被创建后自动触发。

    • PaymentVerificationInventoryReservation:当支付对象的状态变为Confirmed(已确认)时触发。

    • InventoryReservationShippingArrangement:当库存对象的状态变为Reserved(已预留)时触发。

  • 关注角度“接下来应该做什么?”。它不关心订单本身是“待支付”还是“已支付”,它只关心支付验证这个活动是否已经完成,从而决定流程是否进入库存预留阶段。

2. 业务对象状态机(以Order对象为例)

  • 状态

    • Draft:草稿。

    • PendingPayment:待支付。

    • Paid:已支付。

    • Shipped:已发货。

    • Delivered:已送达。

    • Cancelled:已取消。

  • 转换触发

    • PendingPaymentPaid:由pay()操作触发。

    • PaidShipped:由ship()操作触发。

  • 关注角度“这个订单当前能做什么?”。它定义了业务规则:订单必须在Paid状态下才能执行ship()操作。它不关心发货这个动作是系统自动触发还是人工触发。

二者如何协同工作?

在上例中,系统级工作流状态机是导演,业务对象状态机是演员。

  1. 工作流处于PaymentVerification阶段。这个阶段的活动会调用支付网关,最终将支付对象的状态改为Confirmed

  2. 支付对象状态变为Confirmed这个条件,触发了工作流状态机从PaymentVerification转换到InventoryReservation

  3. 工作流进入InventoryReservation阶段,该阶段的活动尝试预留库存。若成功,则将库存对象的状态改为Reserved

  4. 库存对象状态变为Reserved,触发了工作流状态机转换到ShippingArrangement阶段。此阶段的活动会调用ship()操作,从而将订单对象的状态从Paid变为Shipped

结论

系统级工作流状态机关注的是过程的进度和协调,其状态是宏观的活动阶段,转换依赖于阶段成果(常体现为其他对象的状态变化)。

业务对象状态机关注的是单个实体的合法演变,其状态是微观的业务状态,转换由具体的业务操作触发。

二者通过事件和条件紧密耦合:业务对象的状态变化作为事件,驱动工作流状态机的阶段转换;而工作流状态机的阶段活动,又是触发业务对象状态改变的主要执行者。理解这种区别与联系,对于设计清晰、可维护的复杂系统至关重要。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/31 9:21:11

Flutter Widget核心概念深度解析

Flutter Widget核心概念深度解析:构建响应式UI的基石 引言:为什么Widget如此重要? 在Flutter的世界里,一切皆为Widget。这个看似简单的设计哲学背后,蕴含着构建高效、响应式用户界面的深刻智慧。对于从其他UI框架转向F…

作者头像 李华
网站建设 2026/1/31 1:01:56

【VSCode模型可见性切换终极指南】:5分钟掌握高效代码导航技巧

第一章:VSCode模型可见性切换的核心概念Visual Studio Code(简称 VSCode)作为现代开发者的主流编辑器,其高度可定制化的界面与功能极大提升了编码效率。在复杂项目中,开发者经常需要动态控制代码模型的可见性&#xff…

作者头像 李华
网站建设 2026/1/28 10:51:10

教育行业如何借助ms-swift打造个性化AI辅导系统

教育行业如何借助 ms-swift 打造个性化 AI 辅导系统 在今天的在线教育平台上,一个初三学生正为一道几何题焦头烂额。他拍下作业本上的题目上传到学习APP,几秒后,AI不仅准确识别了手写内容,还用动画形式一步步推导出解法&#xff0…

作者头像 李华
网站建设 2026/1/24 5:08:06

ESP32开发环境搭建项目应用:结合Arduino IDE实战

从零开始玩转 ESP32:Arduino IDE 环境搭建实战全记录 你有没有过这样的经历?买了一块崭新的 ESP32 开发板,兴冲冲地插上电脑,打开 Arduino IDE,结果点击“上传”时却弹出一串红字:“ Connecting… failed!…

作者头像 李华
网站建设 2026/2/1 22:22:37

揭秘中文物体识别:如何用云端GPU快速验证你的创意

揭秘中文物体识别:如何用云端GPU快速验证你的创意 如果你正在开发智能家居项目,需要快速验证不同开源物体识别模型的准确性,但又被复杂的本地环境搭建劝退,这篇文章正是为你准备的。我们将介绍如何利用云端GPU环境,跳过…

作者头像 李华
网站建设 2026/1/30 9:20:46

法律条文通俗化翻译工具

法律条文通俗化翻译工具:基于 ms-swift 框架的大模型工程化实践 在数字时代,法律不再是法官和律师的专属语言。越来越多的普通人开始关心自己的权利义务——从租房合同是否合规,到交通事故如何维权。但现实是,哪怕只是翻看《民法典…

作者头像 李华