DDD落地過程中關(guān)于值對(duì)象建模的思考

前言

值對(duì)象是狀態(tài)不可變的、可整體替換的、用于度量和描述領(lǐng)域中某件東西的對(duì)象。在落地DDD過程中我們常常遇到一個(gè)概念到底是建模成實(shí)體好還是建模成值對(duì)象好這種問題,其實(shí)各DDD大神早已經(jīng)給出了答案,prefer value object to entity!

值對(duì)象建模

0、值對(duì)象不包含改變屬性的方法

  • 值對(duì)象里沒有改變自身狀態(tài)的方法,只有查詢方法,根據(jù)迪米特法則和告訴而非詢問原則決定查詢方法是public還是protected
  • 想要改變值對(duì)象狀態(tài),就新建一個(gè)值對(duì)象過來替換

1、值對(duì)象要包含領(lǐng)域邏輯

  • 值對(duì)象雖然是不可變的,但是值對(duì)象本身可以利用自己的屬性去完成一些領(lǐng)域邏輯,而且建議把領(lǐng)域邏輯寫到值對(duì)象里。
  • 實(shí)體盡量作為值對(duì)象的對(duì)外接口

2、迪米特法則

  • 迪米特法則要求一個(gè)對(duì)象對(duì)另一個(gè)對(duì)象內(nèi)部結(jié)構(gòu)知道的越少越好,在代碼體現(xiàn)上就是一個(gè)聚合根實(shí)體內(nèi)部的值對(duì)象的屬性和方法盡量都是protected以上級(jí)別的,這樣包外部就沒辦法訪問到實(shí)體內(nèi)部的值對(duì)象,只有實(shí)體可以調(diào)用值對(duì)象的方法,值對(duì)象想要對(duì)外提供服務(wù)必須通過聚合根實(shí)體的代理。這種實(shí)現(xiàn)是符合高內(nèi)聚低耦合原則的!但是需要在聚合根實(shí)體中實(shí)現(xiàn)大量的代理代碼。

3、告訴而非詢問原則

  • 告訴而非詢問原則在迪米特法則基礎(chǔ)上有放寬值對(duì)象的訪問級(jí)別。即值對(duì)象可以對(duì)外提供用于查詢的public方法,而對(duì)對(duì)象(此處指聚合跟實(shí)體中引用的其他實(shí)體對(duì)象,非值對(duì)象)狀態(tài)有修改的方法則被修飾為protected。有時(shí)我們需要值對(duì)象返回一個(gè)collection類型的屬性,這個(gè)原則要求我們暴露的是不可改變的屬性,比如Collections.unmodifyed(map),或者利用新建一個(gè)副本對(duì)象的方式提供返回。

在落地實(shí)踐中,以上兩個(gè)原則都是可以落地的,區(qū)別在于聚合根實(shí)體是否直接代理值對(duì)象的方法,這也決定了聚合根實(shí)體中代理方法代碼量的多少。在落地過程中可以根據(jù)自己的實(shí)際需要進(jìn)行選擇。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容