news 2026/4/23 10:12:52

系统级的Activity Diagram,Object Node如何表示?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
系统级的Activity Diagram,Object Node如何表示?

如果是system-level的Activity Diagram,其中的Object Node如果不体现Object是否可以?比如状态“Awaiting shipment”,不属于某一个对象的状态,但system-level的workflow更关注它。

在系统级活动图中,纯粹表示流程阶段的“Awaiting shipment”不应该也不适合用一个独立的Object Node来表示。

以下是详细的分析和正确的建模方法。

为什么“Awaiting shipment”不适合作为Object Node

因为Object Node在UML语义中定义明确:它代表一个数据或对象的实例在流中的存在

  • “Awaiting shipment”描述的是一个流程实例(Process Instance)所处的阶段或里程碑。

  • 它不是一个可以被创建、传递、转换或销毁的数据对象。您无法将它从“Validate Order”活动输出,再输入“Ship Order”活动。

  • 将其表示为Object Node会混淆建模概念,导致模型难以理解和实现。

正确表示方式:将流程状态“内化”于活动图中

系统级活动图本身就有强大的机制来表达工作流自身的状态,无需借用Object Node。以下是几种标准且清晰的做法:

方法一:使用“活动状态”本身作为流程状态
这是最自然、最常用的方式。活动图中的每一个活动(Activity)都代表工作流正在执行的一个任务。当控制流(Control Flow)位于某个活动时,就意味着工作流处于该活动所代表的状态。

  • 示例

    text

    [开始] -> [订单验证] -> [库存预留] -> [等待发货] -> [执行发货] -> [结束] ^ ^ | | 流程状态:“库存预留中” 流程状态:“等待发货中”
    • 解释:当令牌(Token)位于[等待发货]这个活动节点时,整个工作流实例就处于“Awaiting shipment”状态。这是一个隐式但极其清晰的状态表示。

方法二:使用“流程数据存储”或“信号”作为显式状态标志
如果需要显式地查询或触发基于此状态的条件,可以引入一个代表流程本身的Object Node或使用信号。

  1. 流程数据对象

    • 创建一个代表工单流程上下文的对象,如OrderFulfillmentWorkflow

    • 它的一个属性可以是currentPhase = "AwaitingShipment"

    • 此对象可以作为Object Node在活动图中流动,并被相关活动读写。这实际上是将流程状态“物化”了。

    • 示例对象节点wfContext : WorkflowContext [phase="AwaitingShipment"]

  2. 发送/接收信号

    • 在进入“Awaiting shipment”阶段时,活动图可以发送一个信号SignalAwaitingShipment

    • 其他系统或计时器可以监听此信号,并在条件满足时发送回复信号来触发后续活动(如SignalProceedToShip)。

    • 这种方式非常适合跨系统、异步的流程协调。

总结与对比

概念错误表示 (作为Object Node)正确表示
“Awaiting shipment”一个独立的Object Node,含义模糊,无法操作。1. 活动节点[等待发货]活动本身就是状态。
2. 流程数据对象wfCtx.phase = "AwaitingShipment"
3. 信号事件:发送SignalAwaitingShipment
关注点混淆了“数据状态”和“控制状态”。分离关注点
• 活动图表达控制流(流程状态)。
• 对象节点表达数据流(对象状态)。
对设计的指导不明确,会导致设计出奇怪的类或属性。清晰
• 方式1:直接对应一个服务或函数。
• 方式2:对应一个流程控制实体类。
• 方式3:对应消息队列或事件系统中的事件。

结论
对于系统级工作流,其状态(如“Awaiting shipment”)应通过活动图的控制结构本身(活动、决策、事件)来体现,这才是活动图的精髓所在。而Object Node应严格用于表示在流程中被处理、传递的数据或业务对象实例

因此,在您的模型中,“Awaiting shipment”应该就是活动图中的一个活动,或者是某个流程控制对象的一个属性值,而绝不应当是一个漂浮在流中的、没有归属的Object Node

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

VSCode智能感知总出错?5分钟定位并修复会话异常问题

第一章:VSCode智能体会话异常问题概述 在使用 Visual Studio Code(VSCode)进行开发时,部分用户反馈其智能体会话功能频繁出现异常,表现为代码补全延迟、建议列表不完整或完全失效。此类问题不仅影响开发效率&#xff0…

作者头像 李华
网站建设 2026/4/22 16:07:19

记一次 .NET 某MES上位机拍照系统 内存暴涨分析

一:背景 1. 讲故事 这是训练营里的一位朋友找到我的,说他们的系统会有偶发的内存暴涨情况,自己也没分析出来,让我帮忙看下怎么回事,拿了一个20G的dump文件,这文件是够大的,我个人建议一般是不超…

作者头像 李华
网站建设 2026/4/15 3:28:19

从零到上线:24小时打造你的专属‘识万物‘App

从零到上线:24小时打造你的专属识万物App 作为一名前端工程师,参加黑客马拉松时最头疼的莫过于AI模型部署。最近我想开发一个能识别生活用品的应用,UI设计对我来说不是问题,但深度学习环境的搭建却让我望而却步。经过一番探索&…

作者头像 李华
网站建设 2026/4/20 8:44:33

万物识别标注工具集成:从数据标注到模型训练的捷径

万物识别标注工具集成:从数据标注到模型训练的捷径 作为一名数据标注团队的负责人,你是否经常遇到这样的困扰:团队成员用不同工具标注的数据格式五花八门,转换起来费时费力;好不容易整理好数据,又要折腾环境…

作者头像 李华
网站建设 2026/4/16 16:13:57

万物识别模型联邦学习:快速搭建分布式训练环境

万物识别模型联邦学习:快速搭建分布式训练环境 联邦学习作为一种新兴的隐私保护机器学习范式,正在物体识别领域展现出巨大潜力。但对于大多数研究者来说,搭建分布式训练环境往往需要耗费大量时间在环境配置和调试上。本文将介绍如何利用预配置…

作者头像 李华
网站建设 2026/4/21 1:50:49

ms-swift支持国产Ascend NPU,国产化算力新选择

ms-swift 支持国产 Ascend NPU,开启大模型国产化算力新篇章 在AI从实验室走向产业落地的今天,一个核心问题正日益凸显:我们能否在不依赖国外高端GPU的前提下,高效完成大模型的训练、微调与推理?尤其是在金融、政务、能…

作者头像 李华