news 2026/5/1 3:34:51

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

作者头像

张小明

前端开发工程师

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/4/30 15:51:42

科研经费预算编制助手

ms-swift:大模型科研的工程中枢与效率引擎 在今天的AI实验室里,一个现实问题正反复上演:研究者手握创新想法,却卡在模型跑不起来——显存溢出、训练太慢、部署成本高得离谱。申请到的几块A100还没捂热,预算就见底了&am…

作者头像 李华
网站建设 2026/4/30 8:23:26

保险理赔问答系统集成:Qwen3Guard-Gen-8B防止误导承诺

保险理赔问答系统集成:Qwen3Guard-Gen-8B防止误导承诺 在保险行业,客户一句“这情况能赔吗?”背后,可能潜藏着巨大的合规风险。如果AI回答“肯定能赔”,看似安抚了情绪,实则埋下了法律纠纷的种子——这种绝…

作者头像 李华
网站建设 2026/5/1 6:19:19

解放生产力:用现成镜像加速AI识别项目

解放生产力:用现成镜像加速AI识别项目 作为一名在小型科技公司负责技术架构的工程师,我深刻理解团队在启动新AI项目时的痛点:每次都要重复配置环境、安装依赖、调试兼容性,这些繁琐的准备工作严重拖慢了项目进度。直到我们发现了预…

作者头像 李华
网站建设 2026/5/1 6:18:43

Oracle:大量数据删除

在Oracle数据库中处理大量数据的删除操作时,需要采取谨慎的策略,以确保操作的效率和避免对数据库性能造成过大影响。以下是几种处理千万级数据删除操作的推荐方法: 1. 使用DELETE语句对于较小的数据集,可以直接使用DELETE语句&…

作者头像 李华
网站建设 2026/5/1 6:19:59

创业公司低成本启动方案:用ms-swift快速验证产品原型

创业公司低成本启动方案:用ms-swift快速验证产品原型 在AI原生应用的浪潮中,越来越多创业团队试图以大模型为核心构建创新产品。然而现实往往是残酷的——设想中的智能客服、个性化推荐或自动写作助手,在落地时却卡在了训练环境搭建、显存不足…

作者头像 李华
网站建设 2026/4/30 18:39:23

ms-swift支持远程协作白板内容生成

ms-swift赋能远程协作白板的智能生成 在远程办公日益普及的今天,团队协作早已从简单的文字沟通转向更直观的视觉表达。白板工具如Miro、Figma Whiteboard或腾讯文档脑图,已成为产品设计、会议讨论和教学讲解的核心载体。然而,一个普遍痛点也随…

作者头像 李华