摘要 随着嵌入式硬件和软件技术的发展,J2ME应用程序的复杂度和代码量越来越大,使得传统的单一类设计模式和框架结构已不能适应需求。本文提出了一种基于Model-View-Controller(MVC)模式的J2ME应用程序框架的设计方法,使得程序更清晰,维护更方便,极大地提高了开发的效率。本文首先介绍了MVC模式的概念;接着提出几种MVC在J2ME应用程序上的设计模式,并分析了各自的特点;最后总结了这种设计模式的优缺点。
关键词 J2ME MVC应用程序框架
1 J2ME应用程序框架的现状
Sun公司在1999年6月推出了J2ME(Java 2 Micro Editionwww.cechina.cn,Java 2袖珍版)。J2ME专门为那些使用有限电源、有限网络连接以及有限图形用户界面能力的设备开发的,满足了消费电子和嵌入式设备开发的需要。
而7年后的今天,消费电子和嵌入式设备发展迅速。硬件设备速度越来越快,存储容量也越来越大,这也就自然带动了软件的发展。MIDP 2,O和CLDC l.1也相继问世,各种各样的JSR也层出不穷。
硬件平台和软件平台的飞速发展自然带动了们需求的
通常来说,J2ME程序都是比较小的,多数在100 KB以下。而且其中大部分是图片和声音,代码只占其中很少一部分。在J2ME程序比较小时,为了提高程序的执行效率,通常的做法是其用一个类完成整个应用程序,在回调函数commandAction()中完成所有界面切换的工作。
例如:
这种模式的好处在于代码量最小,能得到最小的jar包尺寸,执行起来效率也最高;而且,因为所有界而都在同一个类中,它们可以很方便地共享数据。
但如果界面很多,程序很大,这种模式就体现出它的劣势了。一方面,几千行的代码集中在一个类里控制工程网版权所有,调试和维护非常不方便。另一方面,由于很多界面都在同一个类中共享数据,使得它们的耦合度大大提高。如果要替换或修改其中某个界面,很可能会影响到其他界面。这就给开发程序带来了很大的不便。
随着嵌入式硬件的发展,J2ME软件的复杂度也越来越大,上述设计模式已不能适应嵌入式发展的需求。这就需要一个更好的设计模式来取代以前的简单设计模式。下面就介绍一下如何把MVC设计模式应用到J2ME程序设计中。
2 MVC模式的简介
MVC由Trygve Rcenskaug提出,首先被应用在SmallTalk-80环境中,是许多交互和界面系统的构成基础,Microsoft的MFC基础类也遵循了MVC的思想。目前这种模式已经非常成熟,并在WEB Application的开发中广泛使用,apache的开源项目struts就是典型的例子。
MVC的英文全称是Model_View-Controller,即把一个应用的输入、处理、输出流程按照Model、View、Con-troller的方式进行分离。这样一个应用被分成3个层--模型层、视图层和控制层。
模型、视图与控制器的分离,使得一个模型可以具有多个显示视图。如果用户通过某个视图的控制器改变了模型的数据,那么所有其他依赖于这些数据的视图都应反映出这些变化。因此,无论何时发生了何种数据变化,控制器都会将变化通知所有的视图CONTROL ENGINEERING China版权所有,实现显示的更新。这实际上是一种模型的变化一传播机制。模型、视图、控制器三者之间的关系和各自的主要功能如图1所示。
3 基于MVC模式的J2ME应用程序框架
MVC是一种很好的客户端软件设计模式,但目前一般只用于PC上。以JAVA为例,目前已经可以看到MVC大量地应用在J2EE和J2SE上,可是几乎还很少见到在J2ME上使用MVC模式。这是为什么呢?有以下两点原因:
①太部分的J2ME应用都很简单,开发周期也很短,很多开发人员偏爱把所有代码写在一个类中,认为没有必要使用复杂的设计模式;
②使用MVC模式在某种程度上会增大代码的体积,并且有可能在一定程度上影响程序的执行效率,这在资源相对有限的J2ME系统上是一个不可忽视的问题。
可是随着嵌入式硬件的发展,移动设备的性能有了很大的提高,从而带动了应用软件的发展。J2ME应用软件变得越来越复杂控制工程网版权所有,如果还像以前那样使用一个类来完成所有的代码,必将使得程序可读性差、扩展性差、可维护性差。然而控制工程网版权所有,如果把MVC模式应用在J2ME应用程序设计中,就可以解决以上的问题。下面列举并分析几种在J2ME中比较适合的MVC模式。
3.1 单一控制器的MVC模式
MVC模式是大家都比较熟悉的,整个程