dev2dev.bea.com.cn
首页 资源中心 dev2dev学堂 在线技术论坛 专家Blog User Group CodeShare

分层模式中的常见问题

2008-03-16 17:00:40 | 评论 (2) | 被访问(462)次

蔡超
  姓名: 蔡超 生日: 1976-09-03 总结: 六年大企业软件开发经验(其中两年任软件架构师),精通J2EE相关技术及架构设计,是SUN及Microsoft培训中心特邀高端讲师 SUN认证的J2EE架构师(SCEA JEE1.2&5.0) SUN认证的商务组件开发员(SCBCD) IBM认证的RUP专家 IBM认证的OOA&D (UML v2)专家


引言
分层结构是目前复杂应用系统开发时普遍使用的模式,软件中层之间的依赖关系约束是比较宽松的,并不要求上层仅可以依赖于直接下层,而是上层可以依赖于它的所有下层。
设计中我们会把各种系统的各种组件映射至不同层中,而在我所接触的一些实际项目中设计人员在映射这种组件和层间的关系时经常无意中破坏了层结构的依赖关系约束。

 

图表 1 典型分层结构

设计中的常见问题
问题一:数据传输对象(DTO)是否应该属于业务层?
在J2EE开发的经典著作《Core J2EE Patterns》中数据传输对象被划分在业务层模式中,那么是否数据传输对象应该被映射到业务层呢?
数据访问对象(DAO)在该著作中是被映射到整合层的,这样就会出现一个违反层依赖约束的问题,因为数据访问对象是要依赖于数据传输对象的,因此下层就会出现对上层的依赖了。
所以本人认为DTO是在各层中传输数据的,我们可以不必强求的把他们映射到上述层次中,可以把他们放置在一个公共包中。
 
问题二:使用POJO作业务对象的轻量级架构与上述层模型的映射
在使用POJO的轻量级结构中我们通常会使用持久化框架(如Hibernate/JPA)同时会在架构中引入仓库对象(Repository Object),负责业务对象的获取和保存。(注意:他的功能和DAO是有区别的,仓库对象中通常只应包括业务对象的获取和保存逻辑)。
通常设计人员会把业务对象映射至业务层,而将仓库对象映射至整合层。由于仓库对象对于业务对象的依赖关系就会破坏依赖关系约束,所以这种映射方式显然不正确。
下图是作者推荐的映射方式

 

图表 2 轻量级架构参考模型

 
可以看到业务对象和仓库对象都被映射至业务层,而持久化框架被映射到了整合层。
 
总结

因此大家在设计过程中不要仅仅将分层结构留于形式,而要时刻注意设计是否符合这种架构模式,这样才能真正发挥这种架构模式的优势。

 

蔡超
JavaEE 咨询顾问
SCEA (1.2&5.0)
IBM Certified Solution Designer for OOA&D UML2


Tags: Architecture
文章评论:(以下网友留言只代表个人观点,不代表BEA观点和立场)
回复人: chaocai  2008-03-17 17:41:06

你说的不无道理,不过软件模式作为前人的经验,如果你用了就要掌握它的本质,发挥它的特定,不要留于形势.例如分层模式会提高系统的可以维护性,但是会影响系统的性能,之所能提高系统的可维护性就来在于它的特性,包括依赖关系的约束.

回复人: 超级菜鸟  2008-03-17 17:12:53

软件设计不是作八股文,分层设计只是一种设计手段,为什么非要把所有逻辑都强行规入到哪一层? 以什么书什么著作作为设计标准本身就是不可取的.我们既没有必要考虑什么分层,更没有必要看符合什么架构模式,只要满足功能和性能,你设计的系统不符合什么层次,也不符合什么模式,但你的系统本身就可以成为别人学习的模式.

2008年03月

          1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31            
RSS订阅

蔡超's Blog搜索