天天看点

DDD:四色原型中Role的 “六” 种实现方式

背景

一个实体在不同的上下文中具备不同的职责,如:产品在“生产完成上下文”中具备的一些职责,在“质检相关上下文”中具备另外一些职责。四色原型、DIC和“UML事物模式”在不同的维度阐述了这一情况,在代码层面到底该如何表达呢?本文给出了一些思路。

六种实现方式

因为:MI(Manufacture和QualityTesting)和Context(ManufactureContext、QualityTestingBeginningContext和QualityTestingCompletingContext)都是空实现且每种风格中的代码都一样,后面只给出跟PPT和Role相关的代码。

类图

DDD:四色原型中Role的 “六” 种实现方式

代码

DDD:四色原型中Role的 “六” 种实现方式
DDD:四色原型中Role的 “六” 种实现方式
DDD:四色原型中Role的 “六” 种实现方式
DDD:四色原型中Role的 “六” 种实现方式

时间不够了,这种实现方式需要独立写一篇文章。

如何设计Context?

PPT对应的Role会参与到一个到多个Context中,一般来说一个Context涉及一个MI,如果MI为“Moment”,多数情况需要一个Context,如果MI为“Interval”,多数情况需要两个Context,根据MI的业务生命周期不同,所需的Context也不同。

备注

仓促写完,还没有具体深入分析如何做出不同的选择和折中,群里有朋友实战过,有机会再写一篇这样的文章。