Domain Model:
特點:
有一系列的實體對象,每個對象不只包含數(shù)據(jù)更重要的包含各自的行為責任。每個對象只做自己的事情,多個對象通過協(xié)作共同完成一件事情??梢猿浞职l(fā)揮面向?qū)ο蠛湍J降淖饔谩?/span> 很符合面向?qū)ο蟮奶匦浴?/span>
優(yōu)點:
處理復雜多變的系統(tǒng)有很大優(yōu)勢,可以很好發(fā)揮(Gof)模式的作用。
缺點:
O/R mapping 是件比較麻煩的事。
說明:
有兩種風格的Domain Model:
1. 每個對象對應于數(shù)據(jù)庫中的表中一行。 Active Record模式
2. 有很多的對象(由于使用繼承和模式,比如一個接口,多個實現(xiàn)類) Data Mapper模式
一系列的實體對象如何存儲需要仔細考慮,一些簡單的應用可以將他們從數(shù)據(jù)庫中全部載入,如果對象很多,那么有時需要按需載入。如果是服務器上的對象那么還要考慮使用session進行管理。同時O/R mapping 也是一個要注意的問題。
使用Domain Model很容易引起對象臃腫。比如為了讓Contract對象可以在UI中被操作,那么就需要在Contract類中添加專門的函數(shù),如此一般對象就容易變的很大。這時候可以考慮將一些通用的操作提到專門的類中,甚至提到其他層,比如UI層。但是如果提到其他地方,人們有時就會忽略它,以致再寫一次,產(chǎn)生不必要的重復。Martin建議還是放在原來的類中,因為這種對象臃腫的現(xiàn)象往往比預期的少,就算發(fā)生也容易發(fā)現(xiàn)并修改。
此處Martin還提到了EJB,個人不是太了解,總之他覺得EJB1.0不太好,建議使用POJO(plain old java objects)就是常見的自定義的java對象。除非是那種小的對象系統(tǒng),比如沒怎么用到繼承,模式的系統(tǒng)可以使用EJB中的Entity Bean。
他還提到Entity Bean不能re-entrant,這是它的主要缺陷。(誰來解釋一下,我看的一知半解)而且CMP的O/R mapping也是支持有限。不過他對EJB2.0好像評價不錯,現(xiàn)在3.0都出來了,哪位高人介紹一下啊。
涉及模式:
簡單類結(jié)構(gòu)Active Record 復雜用到多態(tài)和模式的類結(jié)構(gòu)DataMapper
注:此處僅為個人的簡單理解,歡迎指教。