DDD:用 “四色原型” 进行 “职责分配”

这篇博客是DDD:用 “四色原型” 进行 “聚合设计”的延伸版。

职责分配

聚合

维护内部状态的一致性。换句话说,聚合的职责只限于维护期自身的状态。可以将聚合的职责分为两类:

  1. 修改职责:只能修改聚合本身的状态,关联的其它聚合信息不能修改。
  2. 读取职责:可以读取聚合本身的状态,关联的其它聚合信息也能读取。

角色

维护一个聚合实例业务逻辑的一致性。因为有些聚合实例的业务逻辑会依赖很多外部服务:如仓储、领域服务等。常见的场景如下:

  1. 前置条件:修改内部状态时,必须满足的条件。
  2. 唯一性验证:某些状态必须唯一。
  3. 计算逻辑:此处多数采用状态模式或策略模式。

领域服务

维护多个聚合实例(跨聚合)业务逻辑的一致性。

工厂

维护聚合的创建逻辑。

仓储

维护聚合的持久化逻辑。

 引入工作单元后的聚合生命周期

代码示例

分析模型

设计模型

项目结构

代码下载

感谢360云盘提供的空间:http://yunpan.cn/QWqewDLDKY4vk

 

posted on 2013-04-26 13:30  幸福框架  阅读(2936)  评论(4编辑  收藏  举报

导航

我要啦免费统计