二十四年前在UMLChina谈本体论-James Odell

DDD领域驱动设计批评文集

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

《软件方法》各章合集


二十四年前啊

2002年,上上个马年。下图是当年的春晚节目,侯耀文还在,郭德纲还没发迹。

图1 2002年春晚节目《马年赛马》

James Odell(Jim Odell)是谁?

下面是Martin Fowler《分析模式》的前言:

图2 《分析模式》2026新译本片段

《分析模式》所使用的方法学和表示法就是James Martin和James Odell的Martin-Odell方法学和表示法。

《分析模式》的新译本用UML类图、序列图、活动图、状态机图复刻了原书的图,不过,新译本的出版已经拖了比较长时间。前一阵,我发了一个视频(https://www.bilibili.com/video/BV1EerQBjE4a/)说了原因,出版的流程现在变慢。我也说了,万一有什么事情出不来,我会怎么做。

和James Odell的交流

北京时间2002年4月26日上午,我们邀请James Odell到UMLChina的聊天室做了一次交流。

当时是在焦点网(smiling.com.cn,不是现在的焦点科技)的聊天室,就是文字交流,没有语音,更没有视频。2002年嘛,我到2002年3月才用上ADSL,即所谓的宽带,之前一直都是Modem拨号上网。

聊天记录在:umlchina.com/Chat/odell.htm

图3 和James Odell的聊天记录

后来我们把这个聊天记录整理翻译,发表在《非程序员》电子杂志上面。《非程序员》是我们办的一个电子杂志,在这里可以免费下载:umlchina.com/xprogrammer/index1.html

图4 《非程序员》2002年5月杂志封面

内页如下,主要的议题还是UML。当时Odell是对象管理组织(OMG)面向对象分析设计专责小组的主席,负责UML 2.0规范的开发。

图5 《非程序员》2002年5月内页

然后Odell提到了本体(ontology):

图6 《非程序员》2002年5月内页

注意Odell所说的"正规数学训练"。

Odell在他的书里面也提到了Ontology,像这本1998年的UML书:

图7 摘自Advanced Object-Oriented Analysis and Design Using UML

注意划线处的Object Constraint Language(OCL),《分析模式》新译本中,大量使用OCL取代了英文原书形式化不足的描述。

我们也针对时事热点(大展鸿图、杨某媛、订婚彩礼)出过很多题来考察OCL,感兴趣的同学可以去自测,参见《软件方法》强化自测题的"分析"部分(umlchina.com/url/examad.html)

图8 2025年热点相关的OCL题目

回顾的缘由

之所以回顾二十四年前的这一段访谈,原因当然是最近爆火的Palantir和本体论。

我不断被人问:

潘老师,你怎么看最近爆火的这个Palantir和本体论?

当然我不能说我坐着看,因为问的人是比较认真地问。

我主要关注两个事情:

(1)有哪些人特别激动地去赞美Palantir或者Ontology,像当年赞美领域驱动设计是革命性的创造、划时代的洞见一样?

(2)我经常批评的DDD圈子,是不又开始借助Palantir或Ontology不断地说"我发现"?关于"我发现"的细节,参见《软件方法》2026版第1章(umlchina.com/url/softmeth.html)

关于(1),根据我每天划划划随意阅读的材料,得到这样的印象:

特别激动地去赞美Palantir或者Ontology的,多为文科生,因为很多人在谈哲学,而不是数学。

什么?我搞错了?你说你是软件专业人士?

不好意思,也许吧,但有没有这样的可能,实际上你就是混迹于软件业的、没有受过Odell所说的"正规数学训练"的文科生?

关于(2),我已经看到了一位我曾多次评点的DDD圈子著名布道师的"我发现":

图9 摘自某微信公众号

"彻底变革"、"如果我们还抱着传统的方法不放"

------太可怕了,也太妙了!正愁着手上的东西难啃学不会,不好摸鱼呢,这就宣告变革了、过时了,这可太及时了!赶紧抛弃过去的包袱,轻松迎接新一轮"创新"。

说"需求是核心本体",但又说"结合AI和领域建模(文中的"零件模")"

------领域建模和需求是一回事吗?是不是跟之前的"业务用例"一样(参见《DDD圈子的"业务用例"》)混淆了两个"业务":反正我在谈需求的时候没有谈"技术"(其实是有的),那可不就是"领域建模"吗?

我这些年持续批评领域驱动设计圈子,就是从这位老师的类似言论开始的,参见:"有传统"和王家卫-《分析模式》漫谈13

本文只是开头,后面我还会针对Palantir、Ontology和领域驱动设计圈子慢慢展开来写一系列的文章。

相关推荐
a里啊里啊7 小时前
软考-软件评测师:知识点整理(七)——软件工程
设计模式·软件工程·软考·uml·结构化开发·软件评测师·软件模型
summer1088 小时前
【读书笔记】蛤蟆先生去看心理医生:洞察自我
笔记·产品经理
纸鸢|1 天前
产品文档体系建设指南:从0到1孵化到商业化落地的完整框架
物联网·产品经理
Warren2Lynch1 天前
[特殊字符]️ 综合指南:结合使用 C4 模型与 UML
uml·c4
jackyrongvip1 天前
快速理解本体论
人工智能·本体论
Ting.~1 天前
软件设计师备考笔记【day2】-UML 图解 | 面向对象 | 设计模式
笔记·设计模式·uml
sunneo1 天前
专栏B-产品心理学深度-05-伦理边界
人工智能·产品运营·产品经理·ai编程·ai-native
Kim.Li2 天前
什么是包容性设计?从跨文化、性别到种族多样性的 UX 设计实战
人机交互·产品经理·视觉设计·交互设计·软技能·ui设计
KaneLogger2 天前
从 Anthropic 面试看 AI 产品经理的四个核心信号
面试·产品经理·ai编程
sunneo2 天前
专栏B-产品心理学深度-01-认知偏差手册
人工智能·产品运营·产品经理·ai编程·ai-native