Eric Evans关于聚合的隐喻错误[《软件方法》节选]

2023-10-13 05:18

本文主要是介绍Eric Evans关于聚合的隐喻错误[《软件方法》节选],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

软件方法(下)分析和设计第8章分析 之 分析类图——知识篇(20211227更新)

软件方法(下)分析和设计第9章分析 之 分析类图——案例篇(20211228更新)

8.3.3.3 DDD****话语中的“聚合”

起名和隐喻

DDD话语中也有“聚合(Aggregate)”,和之前各种面向对象方法学以及UML的“聚合(Aggregation)”有一些差别。

Eric Evans在发明新式话语时,应该是借鉴了Aggregation,但为了“创新”,改一个词:Aggregate。DDD话语中的Aggregate相当于整个聚合/组合结构,整体类被称为“聚合根(Aggregate Root)”。

如前文所言,不管是Aggregation还是Aggregate,很容易误解成“累计”或“集合”,混同于各种集合类(List、Queue、Stack……)。

其实Eric Evans应该借鉴的是之前面向对象方法学和UML中的"组合(Composition)",然后发明“Composite”和“Composite Root”。

Eric Evans在发明“Aggregate”新式话语时,应该没有意识到这一点。从他在书中用一串葡萄来隐喻“聚合”就可以看出来。

图8-117 摘自Domain-Driven Design: TacklingComplexity in the Heart of Software, Evans E. , 2003

一大串葡萄就算有一亿颗,也只是同一个类“葡萄”的对象集合。若干颗葡萄、两个煎蛋、一根油条、一杯豆浆、若干张纸巾,再加一把叉子,组成一份早餐,这个才是有意义的“组合”。

图8-118 有意义的聚合/组合

另外,Eric Evans选用这个图片,可能还搞错了另一个知识,不过这个知识不是软件开发知识,而是植物学知识。

植物学上有聚合果(Aggregate Fruit)的概念,如下图

图8-119 摘自百度百科“聚合果”词条

Eric Evans可能想到“Aggregate Fruit”这个术语,觉得葡萄是成串的,以为葡萄是“Aggregate Fruit”,于是把图片放上去了——其实葡萄是单果。

图8-120 摘自https://zhuanlan.zhihu.com/p/37538771

当然,也可能Eric Evans用这个图片的时候,并没有意识到“Aggregate Fruit”之类的概念,觉得图片差不多意思就用上了。


如果要换一个更好的隐喻,可以从1994年出版的Grady Booch书中所给的类比中挑一个。

图8-121 摘自《面向对象分析与设计(原书第2版)》,Booch G. 著;冯博琴 等译,英文原版出版于1994年

实践中的思维颠倒

……


关于聚合,以前还发过一篇文章:猴子掰玉米?比较不同版《领域驱动设计》说“不变式”和“聚合”


DDD领域驱动设计批评-文集-点击查看>>


3月17-20晚剔除“伪创新”的领域驱动设计-网络公开课


UMLChina建模竞赛题大全-题目全文+分卷自测(11套110题)


全程字幕-26套UML+Enterprise Architect/StarUML建模示范视频(202201更新)


《软件方法》书中自测题-题目全文+分卷自测(1-8章)16套111题


这篇关于Eric Evans关于聚合的隐喻错误[《软件方法》节选]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/201010

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消