选主角的DDD

此文想聊一聊软件系统设计中可能会被日常认知所干扰的判断。

业务场景上下文:
新电影开拍,导演需要选择主角。

如果这个时候我们要构建一个给导演用的选角App,我们用DDD的方法论来考虑问题,可能会觉得,演员是个实体。不,其实演员应该是个值对象。
--什么?此处演员是个值对象?主角是个人, 是个实例,为什么DDD中就不是个Entity了?


为什么我们会觉得演员应该是实体,是因为现实生活的认知是,他们的名字就直接映射到了演员这个人,是谁,特点是什么,颜值等信息一瞬间被激活在意识里。我们会直接联系到真实演员的“实例”。

OK。DDD的选角App建模问题应该这样来讲故事会比较好理解吧。
电影开拍前要选角。外籍导演不认识演员也没听说过演员的名字,根据电影题材就只能靠演员身材条件来确定主角。演员经纪人负责与剧组联系并提供一张演员照片参与选角。不幸的是,硬朗帅气身材好的演员的照片被经纪人搞错了,发过来另一位谐星的照片。这种情况下,如果我们再说DDD分析建模,演员在选角App中是实体还是值对象?

此时演员是个值对象而不是实体。因为这个场景中,外籍导演,照片,甚至经纪人,都在刻意构建导演与演员之间不连接的边界。有了这些边界的隔离,我们才能看清,此时导演只能依据一些照片提供的身高, 身材,颜值等值类型去做判断,那当然演员这个对象在导演眼里就只有几个值类型而已。而进一步说,能够胜任主角的演员特质,其实都是值类型,都是实例演员某一时刻(照片中或者你脑海中)的各个值类型属性集合。

惊不惊喜,选角系统的演员真的是值类型。

发散一下,照片应该是个实体,照片有标识。所谓演员的外在属性,其实是照片的属性。颜值与外型都是照片的值对象。然后呢,如果选角上下文暂时结束,照片这个实体应该成为下一个上下文-试镜的关键输入,因为可能需要靠照片找到对应的经纪人以及对应的演员实体。

书里的依据:

  1. [P49]一个对象是用来表示某种具有连续性和标识的事物?还是用于描述某种状态的属性呢?这是Entity与Value Object之间的根本区别。明确地选择这两种模式中的一个来定义对象,有利于减少歧义,并帮助我们做出特定的选择,这样才能得到健壮的设计。
  2. [P59]当一个对象由其标识而不是属性区分时,那么在模型中应该主要通过标识来确定该对象的定义。
  3. 要格外注意那些需要通过属性来匹配对象的需求。
  4. 每个对象分配ID系统就必须处理所有这些ID的跟踪问题。(所以处理不正当的Entity是一件增加复杂度的事情。)
  5. 软件设计要时刻与复杂性做斗争。我们必须区别对待问题。仅在真正需要的地方进行特殊处理。(识别为Entity)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,546评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,224评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,911评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,737评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,753评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,598评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,338评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,249评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,696评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,888评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,013评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,731评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,348评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,929评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,048评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,203评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,960评论 2 355