轉(zhuǎn)自
portian基本上一個應(yīng)用程序里面的領(lǐng)域相關(guān)的模型里面需要3種對象:
1。值對象(Value Object),
沒有身份,內(nèi)容表示一切,譬如我和weihello都去銀行里面存取100大洋,那這個100RMB是一個值對象
2。實體對象(Entity),
需要持久,不是按照內(nèi)容,
而是按照它的身份來區(qū)分,也就是說即使內(nèi)容完全一樣,也不是同一個對象。這個身份在內(nèi)存
里面是它的實例地址,在數(shù)據(jù)庫里面是關(guān)鍵字,最常見的就是OID.這個實體對象并不是純數(shù)據(jù),它處理本身的實體模型,例如Accout,它的
withDraw,它的子Account等等,
它也處理自己和其他實體對象之間的關(guān)系,例如訂單里面的訂單行,都是應(yīng)該在這個Account里面實現(xiàn)的,
而不應(yīng)該有一個什么控制類。在一個Web應(yīng)用程序里面,涉及到對象關(guān)系的一般只需要一個(或幾個)DTOFactory負(fù)責(zé)所有對象的DTO和
Entity之間的組裝和拆份,不需要專門的管理,這一部分也是和數(shù)據(jù)建模最相近的地方。
?
3。服務(wù)對象(Service),這是為我們提供服務(wù)的類,譬如銀行里面服務(wù)員,她幫助我們把錢從一個賬戶轉(zhuǎn)到另外一個賬戶,并記錄相應(yīng)的交易。
對象的作用是對它自己的內(nèi)部狀態(tài)負(fù)責(zé),如果它需要存取很多其它對象的狀態(tài)進(jìn)行運算,那叫做特性忌妒,是要重構(gòu)的。應(yīng)該把這些代碼移到那個持有這些狀態(tài)的類里面
辨別一些名詞:
1。VO:實際上很模糊,通常指ValueObject和ViewObject
2. ViewObject,界面展現(xiàn)需要的對象,如Struts的FormBean
3。Value Object,早期被作為ValueObject和Transfer Object的總稱。實際上Value Object的真正意義在于它的內(nèi)容,而不是身份
4。Transfer Object:數(shù)據(jù)傳輸對象,在應(yīng)用程序不同層次之間傳書對象,在一個分布式應(yīng)用程序中,通常可以提高整體的性能
5。PO:也許就是Persistent Object,基本上就是Entity了
在不同的體系結(jié)構(gòu)和實現(xiàn)方式里面,這些對象有可能重復(fù),也有可能不重疊。如果你要做一個對所有的體系都能夠方便移植的框架,那么每一種對象都需要
嚴(yán)格區(qū)分。例如JDO的PO不能作為TO,應(yīng)為它不能脫離PM,譬如你可以選擇用ViewObject(如Struts的FOrmBean)直接作為
TO,但在tapestry和Webwork里面就不合適了。但在很多時候,能夠方便實用是最重要的,不要過度設(shè)計就是了。