news 2026/3/24 14:22:04

系统级的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/3/20 17:19:34

3分钟实现POSTMAN界面本地化改造

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个轻量级POSTMAN界面修改工具,功能包括:1) 实时DOM检测 2) 文字内容即时编辑 3) CSS注入 4) 修改方案保存 5) 修改回滚。基于Chrome扩展开发&#xf…

作者头像 李华
网站建设 2026/3/13 21:01:06

VS Code + CMake:告别手动配置,提升10倍开发效率

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个VS Code项目,使用CMake管理依赖库。项目需要引用一个外部库(如Boost或OpenCV),并编写一个简单的示例程序使用该库的功能。请…

作者头像 李华
网站建设 2026/3/22 18:50:26

子女教育专项附加扣除:Qwen3Guard-Gen-8B说明申报方式

Qwen3Guard-Gen-8B:语义驱动的内容安全新范式 在生成式AI加速落地的今天,一个看似简单的问题却频频困扰产品团队:“这个回答能发出去吗?” 无论是教育类APP担心学生提问越界,还是跨境社交平台忧虑文化差异引发争议&a…

作者头像 李华
网站建设 2026/3/15 18:48:31

8个降AI率工具推荐!继续教育学员必看

8个降AI率工具推荐!继续教育学员必看 AI降重工具:让论文更自然,让查重更轻松 在继续教育的学习过程中,论文写作是每位学员必须面对的挑战。随着AI技术的广泛应用,许多学生在使用AI辅助写作时,发现论文中存在…

作者头像 李华
网站建设 2026/3/23 8:39:50

深度神经网络输出层设计全解:从理论到实践

深度神经网络输出层设计全解:从理论到实践 在深度神经网络中,输出层的设计直接关系到模型能否解决特定问题。今天我们就来详细探讨输出层的核心设计原则,以及最常用的两种激活函数——恒等函数和Softmax函数。 分类 vs 回归:两种不…

作者头像 李华