DDD四色建模法

DDD四色建模法

四色建模法来源于Peter Coad的 《Java Modeling In Color With UML》,中文版:《彩色UML建模》(末尾处有书籍领取方式,仅用于学习)

Peter Coad和Mark Mayfield奠定了4种架构型(一种形式,所有的东西都或多或少地遵守)的早期工作。

4种架构型 Archetype:

  1. 时刻时段 MomentInterval:一个时刻或一段时间,粉红色表示。
    • 一次销售是在一个时刻完成的——这次销售的日期和时间。
    • 一次租赁发生在一个时间段——从登记入住到归还。
  2. 角色 Role:角色是一种参与方式,它由参与方(人或组织机构)、地点或物品来承担,黄色表示。
  3. 描述 Description:它是“分类目录条目似的”描述,它是一组反复应用的值,它也为所有对应到某个描述的东西提供行为,蓝色表示。
  4. 参与方-地点-物品 PartyPlaceThing:参与方(意味着人或组织机构)、地点或物品是扮演不同角色的人或物,绿色表示。

这4种颜色中每一种都对应一种架构型的特征(属性、链接、方法、插入点和交互),对应的类或多或少都包含了这些特性。

确定一个类的颜色和架构型。
  1. 它是时刻或时段,是出于业务原因或法律原因,是系统需要追踪的东西吗?如果是这样,那么它是粉红色的时刻时段。
  2. 否则,它是一个角色吗?如果是这样,那么它是黄色的角色。
  3. 否则,它是一个分类目录似的描述,包含了一组可以反复应用的值吗?如果是这样,那么它是蓝色的描述。
  4. 否则,它就是绿色的参与方-地点-物品。

实战案例

客户账户管理系统

许多业务利用账户来追踪客户在给定的业务交易背景下的借款项和贷款项。

客户账户管理以申请为起点,终止于账户交易。

在客户账户管理中,我们建立并维护账户,这样就可以从客户的角度来追踪和呈现正在发生的业务。

时刻时段。客户账户管理的主要时刻时段包括

  • 客户账户申请(CustomerAccountApplication)。
  • 客户账户交易(CustomerAccountTransaction)。

客户账户申请

客户账户申请组件有一个粉红色的时刻时段:“客户账户申请”

粉红色的**“客户账户申请”** 链接到3个黄色的角色:

  • 客户账户申请者
  • 申请审批者
  • 负责账户的组织机构实体

“客户账户申请”链接到蓝色的“客户账户描述”,表明这次申请对应哪种类型的账户。
也链接到其蓝色的**“客户账户特征描述”**,分别是选择的特征和附加的特性。

对于一个**“客户账户申请”,它的后续粉红色时刻时段是“客户账户交易”(通过绿色的“客户账户”**)。

关键方法:

  1. 创建客户账户申请。
  2. 检查特征的适用性。
  3. 生成账户。
  4. 评估得到的账户的质量。

图一


客户账户

绿色的**“客户账户”链接到两个黄色的角色,“客户账户持有者”“负责账户的组织机构实体”,它也链接到一个或多个蓝色的“客户账号特征描述”**。

对于**“客户账户”,它的前驱粉红色时刻时段是“客户账户申请”,它的后续粉红色时刻时段是“客户账户交易”**。

关键方法:

  1. 创建客户账户。
  2. 计算日平均账户余额。
  3. 计算日平均容量。

客户账户交易

“客户账户交易”有一个粉红色的时刻时段:“客户账户交易”

粉红色的**“客户账户交易”链接到3个黄色的角色:“客户账户持有者”、“负责账户的组织机构实体”、“作为业务地点的设施”(给定的客户账户事务发生的地点)。它也链接到粉红色的“客户账户交易明细”**。

“客户账户交易明细”链接到绿色的“客户账户”

对于**“客户账户交易”,它的前驱粉红色时刻时段是“客户账户申请”,它的后续粉红色时刻时段是针对该交易的“会计过账”**。

关键方法:

  1. 创建客户账户交易。
  2. 计算客户账户平均交易金额。

最终生成的完整组件模型如图二:

图二

总结

四色建模是建立在UML基础之上的一种新型建模方式,在建模过程中需要按照4个步骤来完成业务领域的建模工作:

  1. 分析业务流程,确认流程中的关键名词,抽象出业务实体。
  2. 从用例入手,找出其中的红色(时刻时段)。
  3. 找出其中的相关元素。
  4. 细化每一个类的方法和属性。

参考资料

  1. Peter Coad:《Java Modeling In Color With UML》

关注【阿飞技术】公众号,后台回复【彩色建模】获取电子版书籍。 \color{red}{关注【阿飞技术】公众号,后台回复【彩色建模】获取电子版书籍。} 关注【阿飞技术】公众号,后台回复【彩色建模】获取电子版书籍。

在这里插入图片描述

  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值