02-通用语言与协作-DDD领域驱动设计


title: "02 通用语言与协作"


学习目标

  • 理解通用语言(Ubiquitous Language)的作用:消除"人脑翻译"
  • 能建立最小可用的词汇表,并把它映射到代码命名
  • 知道如何在模型演化时同步更新语言与代码

核心概念

通用语言(Ubiquitous Language)

通用语言是围绕模型建立的共同语言,要求团队在:

  • 讨论、文档、图
  • 代码中的类名、方法名、事件名、命令名

都尽量使用同一套词汇与定义。

课堂讲授:语言不是"写出来",而是"用起来"

学生最容易犯的错误是把通用语言当"术语表文档"。正确做法是:

  • 词汇表是"约定",但真正的落点是命名交流
  • 发现歧义(同名不同义)时,要么拆词,要么划边界(有界上下文)

最小可用词汇表模板

你需要的不多,但必须完整:

text 复制代码
术语:
定义:
边界(属于/不属于):
同义词(允许):
禁用词(避免混用):
反例(常见误解):
代码命名建议(类/方法/字段/事件/命令):
示例句(业务/代码各一句):

示例:把"创建订单"命名为"下单"

很多系统把接口叫 createOrder,但业务更常说"下单/提交订单"。这不是"语言洁癖",而是减少认知负担:

  • 命令:PlaceOrder
  • 事件:OrderPlaced
  • 聚合:Order
  • 用例(应用服务方法):placeOrder(...)

常见误区

  • 一个概念多种叫法:create/submit/place 混用,最终所有人都不确定差异
  • 用技术词代替业务词:把"订单取消"说成"updateStatus(3)"
  • 词汇表不维护:模型变了,语言没变,造成"旧词新义"

课堂练习(可评分)

给定一段业务描述,输出一个 8~12 条的词汇表,并满足:

  • 至少 3 个术语包含"禁用词/同义词"
  • 至少 3 个术语给出"代码命名建议"
  • 至少 2 个术语给出"反例(常见误解)"

自测题

  1. 为什么说通用语言是"模型驱动"的?
  2. "订单取消"和"订单作废"如果在业务上含义不同,你会怎么做?
  3. 词汇表更新后,哪些地方必须同步更新?

延伸阅读

参考资料索引:references.md

相关推荐
551只玄猫28 分钟前
【数学建模 matlab 实验报告12】聚类分析和判别分析
开发语言·数学建模·matlab·课程设计·聚类·实验报告
小陈工2 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
H Journey2 小时前
C++之 CMake、CMakeLists.txt、Makefile
开发语言·c++·makefile·cmake
提子拌饭1333 小时前
风息时钟:鸿蒙Flutter 实现的自然风格时钟应用
flutter·华为·架构·开源·harmonyos
一定要AK7 小时前
Spring 入门核心笔记
java·笔记·spring
A__tao7 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
KevinCyao7 小时前
java视频短信接口怎么调用?SpringBoot集成视频短信及回调处理Demo
java·spring boot·音视频
科技小花7 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
lly2024067 小时前
C 标准库 - `<stdio.h>`
开发语言
2501_948114247 小时前
2026年大模型API聚合平台技术评测:企业级接入层的治理演进与星链4SAPI架构观察
大数据·人工智能·gpt·架构·claude