分享

博客园 - 企业设计模式读书笔记 Domain Model

 liuqg 2006-03-10

企业设计模式读书笔记 Domain Model

Posted on 2005-01-30 22:06 idior 阅读(1021) 评论(4)  编辑 收藏 收藏至365Key 所属分类: Design

Domain Model:
 

特点:

有一系列的实体对象,每个对象不只包含数据更重要的包含各自的行为责任。每个对象只做自己的事情,多个对象通过协作共同完成一件事情。可以充分发挥面向对象和模式的作用。 很符合面向对象的特性。

 

优点:

处理复杂多变的系统有很大优势,可以很好发挥(Gof)模式的作用。

 

缺点:

O/R mapping 是件比较麻烦的事。

 

说明:

有两种风格的Domain Model

1.   每个对象对应于数据库中的表中一行。 Active Record模式

2.   有很多的对象(由于使用继承和模式,比如一个接口,多个实现类) Data Mapper模式

 

一系列的实体对象如何存储需要仔细考虑,一些简单的应用可以将他们从数据库中全部载入,如果对象很多,那么有时需要按需载入。如果是服务器上的对象那么还要考虑使用session进行管理。同时O/R mapping 也是一个要注意的问题。

 

使用Domain Model很容易引起对象臃肿。比如为了让Contract对象可以在UI中被操作,那么就需要在Contract类中添加专门的函数,如此一般对象就容易变的很大。这时候可以考虑将一些通用的操作提到专门的类中,甚至提到其他层,比如UI层。但是如果提到其他地方,人们有时就会忽略它,以致再写一次,产生不必要的重复。Martin建议还是放在原来的类中,因为这种对象臃肿的现象往往比预期的少,就算发生也容易发现并修改。

 

此处Martin还提到了EJB,个人不是太了解,总之他觉得EJB1.0不太好,建议使用POJOplain old java objects)就是常见的自定义的java对象。除非是那种小的对象系统,比如没怎么用到继承,模式的系统可以使用EJB中的Entity Bean

他还提到Entity Bean不能re-entrant,这是它的主要缺陷。(谁来解释一下,我看的一知半解)而且CMPO/R mapping也是支持有限。不过他对EJB2.0好像评价不错,现在3.0都出来了,哪位高人介绍一下啊。

 

涉及模式:

简单类结构Active Record  复杂用到多态和模式的类结构DataMapper


注:此处仅为个人的简单理解,欢迎指教。

Feedback

# re: 企业设计模式读书笔记 Domain Model  回复   

2005-01-31 10:03 by 纯爷们
我觉得EJB中的Entity Bean,尤其是CMP,实际运用中不可能只靠它,原因我觉得有下面几条:
1.CMP有太多的内在处理,效率是比较低的。
2.因为它是把行记录对象化,当然操作是方便了许多,但是对于批量的数据不太适合,所以曾经有人建议在处理查询的时候还是用JDBC。

不知道是不是我记错了,我觉得在这本书中说的active record模式并不是你笔记里写的对应数据库中的表,而是对应表中的行,从record上也可以看出,实际上在CMP中处理的对象我个人觉得是active record模式。尤其是在Active Record对象中可能要包含操作,比如在CMP中的对于对象的CRUD操作是有的,这可能和Row Data Gateway不一样的地方


个人的拙见,FYI!

# re: 企业设计模式读书笔记 Domain Model  回复   

2005-02-01 13:11 by idior
active record模式确实是对应一行。谢谢提醒,笔误。
能否指教一下re-entrant。

# re: 企业设计模式读书笔记 Domain Model  回复   

2005-02-01 17:11 by 纯爷们
re-entrant,我也不知道,我没有做过J2EE的开发,呵呵!你要是搞懂了记得通知一下:)

# re: 企业设计模式读书笔记 Domain Model re-entrant,  回复   

2005-04-03 18:32 by 陆刚
说 EJB 不能re-entrant,我理解Martin的意思如下:

实际上是一个包依赖关系,你不能从A包调用B包的同时,又从B包调用A包. 其实不光EJB如此,.Net也如此.

可以建立一个Facade层,比如C包,可以向下调用A包和B包,我在.NET是如此实现的,但是EJB如何,我不知道细节.

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多