From:阿里技术专家详解 DDD 系列- Domain Primitive
DP定义:Domain Primitive 是一个在特定领域里,拥有精准定义的、可自我验证的、拥有行为的 Value Object 。
DP概念就像树根,类似于语言中的基础类型,运用DP概念来设计代码,使代码存在以下明显优点:
- 接口清晰度高
- 代码清晰度高
- 业务代码与数据校验逻辑分离
- 可测试性高
运用DP设计的代码,符合或更靠近一些基本的设计原则:
- 单一职责
- DRY
DP原则
- 隐性概念显性化
- 举例:把托盘放入集装箱中,传入托盘对象(Pallet pallet)而不是托盘编号(string palletNumber),托盘的核心业务逻辑在Pallet类中。
- 隐性的上下文显性化
- 举例:存入Order信息到Order表,CreateOrder入参接受一个String OrderNumber,内部逻辑固定把OrderType=105的存入表中。这里的OrderType就是隐性的,当我们创建IT(OrderType=106)的数据时,会存在问题,所以把OrderNumber和OrderType提到Order类中,然后CreateOrder的入参调整为Order。
- 封装多对象行为