[答疑]把缺省伪状态和历史伪状态合并可行吗

DDD领域驱动设计批评文集

做强化自测题获得"软件方法建模师"称号

《软件方法》各章合集


veggieg 2026-4-29 15:05

这样画状态图

没有历史的时候,会转到H指向的B1,B1刚好是B的初始态,我省去黑点指向B1不画,统一用H,这样可行吗?

UMLChina潘加宇

可行是可行,只要能防住不让后面的人把迁移指向B的边界,就是合法的。

(也可以修改规范,既然缺省大黑点没有了,就可以把指向B的边界的迁移解释为指向H,然后把图上所有指向H的迁移改为指向B的边界。)

不过,和原来的意思有差别。就像我每餐不吃两碗米饭了,吃两个馒头行不行,当然行,但不是一个东西。

我把缺省子状态补上,对比一下:

最开始的时候是一样的,没有历史就迁移到B1。

但下次从B退出,就有历史了,那么每次进入B,都要回到离开前所在的子状态。如果这是你想要的,那就没问题。

有个麻烦:如果想下次进入B时迁移到B1,就得在离开前把状态转到B1再离开,因为这时B1才成为历史子状态。

一个值得画的状态机,进入一个状态和离开一个状态的事件可能会有多个(也就是说,图上这样画A、转A、B、转B属于伪创新的一一对应刷废话),是不是通过每一个事件迁移到B时,都希望转到历史子状态,就难说了。

相关推荐
嘿黑嘿呦3 天前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
旧曲重听13 天前
2026前端技术从「夯」到「拉」
前端·程序人生·职场和发展·软件工程
承渊政道3 天前
飞算JavaAI 智能引导背后的多 Agent 协作机制解析:从老旧 Java 后台升级到可运行工程
java·开发语言·spring boot·安全·intellij-idea·软件工程·ai编程
apcipot_rain4 天前
计科八股20260616(1)——堆存中位数、链表判环、黑白测试、敏捷开发与瀑布模型、配置管理、持续集成、池化
数据结构·算法·软件工程
lisw054 天前
【计算机科学技术】路由器(route):概念、历史、内容与战略!
机器学习·智能路由器·软件工程
培培说证4 天前
大数据、人工智能、计算机、软件工程,到底怎么选?
大数据·人工智能·软件工程
文艺倾年5 天前
【强化学习】MDP、贝尔曼方程与CartPole 编程,20W字总结(二)
人工智能·软件工程·强化学习
郝学胜-神的一滴5 天前
CMake 017:彩色日志输出实战
linux·c语言·开发语言·c++·软件工程·软件构建·cmake
小程故事多_805 天前
AI软件工程范式革命,终结五十年的“手工伪工程”时代
人工智能·软件工程
精益数智小屋6 天前
项目管理看板如何拆解任务进度?项目管理看板解决跨部门协作难题
大数据·人工智能·数据分析·云计算·软件工程