ddd的战术篇: domain object之一

本文探讨了DDD中的战术建模,包括Entity(有标识符的可变对象)、Value Object(不可变对象)和Aggregate(由Entity和Value Object组成的集合)。解释了何时使用Entity和Value Object,并通过地址建模的例子加以说明。同时阐述了Aggregate的作用以及Repository的概念,与Active Record模式的区别在于Repository关注业务逻辑而非物理实现,更倾向于充血模式。
摘要由CSDN通过智能技术生成

首先ddd的战术这个讲法是不太好的。ddd书中说的是战术性建模(tactical modeling)。其意思是在战术层面的建模,那当然有战略层面的建模啦。以后会专门讲。

domain object是ddd区别于其他建模/设计方法的一个部分。他定义了概念帮助我们去建立model。如果没有接触过ddd,一开始会觉得有点莫名其妙,为什么要定这种规矩,这种规则?

Entity,value object, Aggregate

entity

entity是一类可识别的可追踪的对象。

说简单了,它必须有identifier,再简单点id(可识别,可被追踪)。

另外它是有可变对象,mutable。但即使状态变化了之后,entity还是原来的entity。(好绕口)

  现实一点的例子。一个人叫“王帝”,他改名交了“王皇”,名字虽然变了,但还是同一人。当然现实世界里我们很难去寻找一个identifier(识别码),如何定义一个不变的identifier会是个哲学问题,但编程时就简单多了,直接搞个id就就行。

value object

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值