news 2026/5/28 16:10:55

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

作者头像

张小明

前端开发工程师

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/5/21 10:33:56

单精度浮点数转换硬件实现核心要点解析

单精度浮点数转换的硬件实现:从标准到实战你有没有遇到过这样的场景?ADC输出一串16位整型数据,却要喂给一个神经网络模型——而这个模型只认float32。在CPU上用一句(float)x轻松搞定的类型转换,放到实时系统里却成了性能瓶颈。这不…

作者头像 李华
网站建设 2026/5/20 12:45:35

多语言文本生成:ms-swift支持全球化业务

多语言文本生成:ms-swift 如何赋能全球化 AI 业务 在出海电商的商品页面上,一段精准且富有本地文化气息的法语描述,可能比直译的英文更能打动巴黎用户;在东南亚市场的客服系统中,能用流利泰语进行多轮对话的 AI 助手&a…

作者头像 李华
网站建设 2026/5/23 11:03:19

Oracle 大表数据分区存储

Oracle 大表数据分区存储是通过将大表按特定规则拆分为多个小表(分区)来优化存储和查询性能的关键技术。 一、分区类型选择‌范围分区(Range Partitioning)‌‌适用场景‌:时间序列数据(如订单日期、交易时…

作者头像 李华
网站建设 2026/5/23 13:43:08

边缘计算应用:轻量级中文物体识别部署指南

边缘计算应用:轻量级中文物体识别部署指南 在嵌入式系统和边缘计算场景中,部署高效的物体识别功能往往面临模型优化复杂、资源受限等挑战。本文将介绍如何通过预置的轻量级中文物体识别镜像,快速在边缘设备上实现高性能的物体检测能力。这类任…

作者头像 李华
网站建设 2026/5/23 3:47:18

图解说明STM32连接无源蜂鸣器驱动电路全过程

从零搭建STM32驱动无源蜂鸣器的完整电路:原理、设计与实战避坑指南你有没有遇到过这样的情况?明明代码跑通了,PWM也输出了,可蜂鸣器就是“哑巴”;或者一发声,单片机就复位,通信乱码,…

作者头像 李华
网站建设 2026/5/21 10:44:59

ms-swift框架下隐私数据脱敏处理模型

ms-swift框架下隐私数据脱敏处理模型 在金融、医疗和政务等高敏感领域,AI系统正以前所未有的速度渗透到核心业务流程中。然而,一个不容忽视的现实是:这些场景中的训练语料往往包含大量个人身份信息(PII)、联系方式、交…

作者头像 李华