该帖已经被评为精华帖
|
|
---|---|
作者 | 正文 |
发表时间:2005-12-15
现在的软件越来越大,越来越复杂,体现在用户交互上尤为明显,导致相关设计开发不再像使用IBM RPG那样简单。开发人员需要了解很多的相关知识才能够开发出一个健壮的Rich Client, 本文就以设计模式为切入点,对此展开讨论,目的是让大家通过本文对GUI设计领域里的一些设计模式有个大概的了解。 看到这个题目,我估计绝大部分朋友会第一时间想到model-view-controller (MVC)模式。的确这个是在GUI设计领域里应用最为广泛的模式了,3个模块相互之间交互,大家耳熟能详,我就不多费笔墨了,不了解的朋友请察看相关资料。本文主要介绍一些大家可能还不太熟悉的模式,让大家对GUI设计领域相关的设计模式有个大概的了解。本文只会对所有的模式进行粗略的介绍,文章末尾列出了每一个模式的原出处,如果哪位朋友对某个模式特别感兴趣可以进行深入的解读。 软件开发总是从小逐渐演变到大,从简到繁。 最初,一个Frame可能只包括一个Panel, 上面只有几个输入栏,几个按钮。可能包含一些展示逻辑(presentation logic),但是这些逻辑是非常简单的,这个时候我们应该使用Autonomous View模式,也就是只用一个类来实现所有的功能。具体来说就是每个window或frame一个类,把实现展示逻辑的代码直接写到view类中。这样做的好处就是方便快捷,缺点就是不太方便测试, 一个类实现了多种功能,任何一个功能的改变都导致类的改变。 随着软件的成长,当view及其相关的展示逻辑变得比较复杂时, view和展示逻辑就需要分开了,就好像当年business logic从service层脱离出来一样。这样做的好处是view和逻辑分离,代码易于共享,易于管理;逻辑功能可以重复使用,易于测试。还有很多其他的好处,介绍MVC的相关书籍已做了详细说明,我就不在这里展开了。 在进行view和逻辑分离的工作中,到目前为止有三种模式可以采用,她们分别是MVC, Model-View-Presenter (MVP), 以及我会重点介绍的Presentation Model. MVC 我在文章开始就提到了不会对她进行展开,不了解的朋友请参考相关书籍。 MVP 由Martin Fowler发现并进行研究,从根本上来说,她只是个MVC的变种。在MVC中view直接处理相关的GUI event,比方说,键盘鼠标事件,checkBox被选中,按钮被按等等。而在MVP中view接收到事件,然后会将它们传递到Presenter, 如何具体处理这些事件,将由Presenter来完成。从class diagram上来看,就是Presenter有View和Model的引用,Presenter负责来管理其他两个模块。跟据两者不同来看,MVC比较适合用来开发components, 而MVP比较适合进行applications的开发, 因为使用MVP导致绝大部分逻辑代码集中在Presenter, 而view变得非常简单, 适当采用良好的编码风格,可以让毫无经验的编码人员稍加培训立刻上岗,大大加速开发view的速度, Presentation Model 也是由Martin Fowler发现并进行研究,从根本上来说就是把所有的逻辑功能完全浓缩到model模块里去,这样我们就只有2个模块:View和Presentation Model。其中View和MVP中的View一样,具有上面提到的所有优点,而Presentation Model则起着承上启下的作用,她连接domain object并将其展现在view上。看到这里聪明的读者可能会发现这个模式有个缺点,就是在view, presentation model, 和domain object之间一定要保持同步。在其他两个模式中,这个功能可以由Controller和Presenter来完成。而在presentation model模式中却没有一个合适的地方来实现, 在view里肯定不行,在model里也不太合适。也就是说当我们使用presentation model进行开发时,我们所使用的框架必须要提供这种同步功能。在windows世界里 .Net data binding就是这种功能的实际实现。如果我们使用Swing开发,很抱歉,Swing没有这种功能。而作为Swing的扩展,JGoodies binding比较完美的解决的这个遗憾。 选择 模式已经介绍完了,到了选择的时候了。其实看到这里大家应该已经有个比较清晰的big picture了。那么当我们进行GUI开发时,何时选用什么模式呢? 我的建议是: 1. 对于简单的view,直接使用Autonomous View. 2. 开发component级别的GUI, 至少要使用MVC. 3. 开发applications, 则应该采用MVP或者是Presentation Model 那么如果是开发application到底应该使用MVP还是Presentation Model呢?这应该是绝大部分开发人员关心的问题。Martin fowler在他的文章中说是it really comes down to how easy it is to do the pattern in your GUI environment and on your own personal tastes. 我觉得不完全对。还记得前面说presentation model有个缺点吧, 就是那个同步的问题。问题总是有两面性的,当我们换个角度来考虑这个问题时缺点就变成了优点了!简而言之,如果再开发中使用了像JGoodies这样的framework,她提供了完善的同步服务,那么我们应该毫不犹豫的使用presentation model, 因为同步问题已被framework解决,应用开发人员不需要投入时间在这些问题上。而相反,使用MVP的话,应用开发人员却不得不面对这些问题,直接导致开发周期延长。另外还有一个使用presentation model原因就是在swing中presentation model已经比较完善(请注意,是比较完善而非完美)得到了实现,比方说ListModel, TableModel,并且针对每一个model也都实现了同步。美中不足就是swing提供的每一个model都是针对具体GUI component的,而且没有提供一个全局同步策略。而JGoodies binding比较完美的解决的这个问题。 最后还要提到一个比较小的模式就是value model,她是value object的变种,她提供了一种set,get,和observe某个对象功能,这个对象通常是个Java Bean,当然也可以是其他的对象类型。这个模式在JGoodies中应用非常广泛,我会在以后的文章中作深入讲解。 相关连接: Autonomous View http://www.martinfowler.com/eaaDev/AutonomousView.html MVP http://www.martinfowler.com/eaaDev/ModelViewPresenter.html Presentation Model http://www.martinfowler.com/eaaDev/PresentationModel.html Organizing Presentation Logic http://www.martinfowler.com/eaaDev/OrganizingPresentations.html Value Object http://java.sun.com/blueprints/corej2eepatterns/Patterns/TransferObject.html JGoodies http://www.jgoodies.com 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2005-12-20
一百多人看,却没有人回,想来应该是大家不开发rich client吧!
估计论坛上朋友99.99% 都是开发Web application的。 |
|
返回顶楼 | |
发表时间:2005-12-20
polygoncell 写道 一百多人看,却没有人回,想来应该是大家不开发rich client吧!
估计论坛上朋友99.99% 都是开发Web application的。 i have already told you that no one cares swing development in china. |
|
返回顶楼 | |
发表时间:2005-12-20
polygoncell兄,我们也做swing客户端,我读了你的帖子,但是不太明白你总结的这些模式都是解决什么问题的,模式都有其固定的应用环境和上下文。而且从MVC这样高层的模式突然跳跃到valueModel这样微观的模式,也确实让我摸不到头脑。
我想问一个具体的模式问题,你们的查询分页是怎么实现的?客户端接口如何写,服务器端需要做哪些工作?如果服务器端还要支持Web接入,那么查询接口如何设计? |
|
返回顶楼 | |
发表时间:2005-12-20
不错,不过我认为这个MVC、MVP这个层面还是比较底层次的,应当把界面从大的方面进行划分,抽象出更高层次的概念。
jgoodies很不错,不过springRichClient的封装层次更高,尤其是它的Form部分很强大。 |
|
返回顶楼 | |
发表时间:2005-12-20
我们也总结了一些模式,分析模式包括:数据展现器、数据提供器、编辑器这些模式等,设计模式包括用fp方式实现的布局抽象,使用JGoodies等实现的一些控件抽象等。
但我觉得我们总结的模式和polygoncell兄总结的模式完全不是一个层面的。 |
|
返回顶楼 | |
发表时间:2005-12-20
snomile 写道 我们也总结了一些模式,分析模式包括:数据展现器、数据提供器、编辑器这些模式等,设计模式包括用fp方式实现的布局抽象,使用JGoodies等实现的一些控件抽象等。
但我觉得我们总结的模式和polygoncell兄总结的模式完全不是一个层面的。 是 Martin Fowler 总结的,jgoodies的binding就是在Presentation Model这个模式下的产物。 Martin Fowler 总结了若干富客户端常用模式,做好富客户端,对这些模式的理解是必不可少的。 http://martinfowler.com/eaaDev/ 这个页面右边有老马总结的富客户端设计模式 Rich Client Window Driver Model View Presenter Event Aggregator Notification Mediated Synchronization Flow Synchronization Presentation Model Presentation Chooser |
|
返回顶楼 | |
发表时间:2005-12-20
snomile 写道 我们也总结了一些模式,分析模式包括:数据展现器、数据提供器、编辑器这些模式等,设计模式包括用fp方式实现的布局抽象,使用JGoodies等实现的一些控件抽象等。
但我觉得我们总结的模式和polygoncell兄总结的模式完全不是一个层面的。 感觉你说的更像是components,而不是design patterns |
|
返回顶楼 | |
发表时间:2005-12-20
关于binding,以下三篇
JGoodies: Understanding Binding - Part 1 JGoodies: Understanding Binding - Part 2 JGoodies: Understanding Binding - Part 3 是比较不错的三篇 |
|
返回顶楼 | |
发表时间:2005-12-20
用Presentation Model,上EclipseRCP吧,比Swing好100倍。
下面是开发中的绑定框架 http://dev.eclipse.org/viewcvs/index.cgi/platform-ui-home/databinding-proposal/databinding.html?rev=1.5 |
|
返回顶楼 | |