news 2026/6/15 13:52:33

系统级的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/6/15 9:56:10

Qwen3Guard-Gen-8B模型适合哪些行业和应用场景?

Qwen3Guard-Gen-8B:语义级内容安全的下一代基础设施 在生成式AI加速渗透各行各业的今天,一个隐忧正日益凸显:大模型在提供强大语言能力的同时,也可能“无意识”地输出违法、歧视或敏感内容。这类风险一旦暴露,轻则引发…

作者头像 李华
网站建设 2026/6/15 11:08:04

运维江湖的五大“门派”,你属于哪一派?

刚入行的时候,亲戚总问我:“你在公司具体干啥?” 我答:“运维。” 对方恍然大悟:“哦!管修电脑、拉网线的!” 我:“……”今天,必须为运维兄弟说句公道话!运维…

作者头像 李华
网站建设 2026/6/15 11:06:01

中文特定领域识别:快速定制预训练模型的实战教程

中文特定领域识别:快速定制预训练模型的实战教程 如果你是一位垂直行业开发者(比如医疗设备领域),想要针对特定场景定制物体识别功能,但又不想从头训练模型,那么这篇教程就是为你准备的。本文将带你快速上手…

作者头像 李华
网站建设 2026/6/15 11:01:49

万物识别模型监控:生产环境指标收集的快速实现

万物识别模型监控:生产环境指标收集的快速实现 作为一名SRE工程师,监控线上物体识别服务的性能是保障业务稳定性的关键。但传统搭建监控系统需要手动集成Prometheus、Grafana等多个组件,配置复杂且耗时。本文将介绍如何通过预装环境快速实现生…

作者头像 李华
网站建设 2026/6/15 7:46:35

通过minicom调试RS485通信的项目应用

用 minicom 调试 RS485?别再靠猜了,这才是工业通信调试的正确姿势你有没有遇到过这样的场景:现场设备一堆传感器通过 RS485 接在总线上,网关就是一块树莓派或工控板,但上电后数据死活读不出来。你改代码、换线、测电压…

作者头像 李华