`
mmdev
  • 浏览: 12952163 次
  • 性别: Icon_minigender_1
  • 来自: 大连
文章分类
社区版块
存档分类
最新评论

易于在各手机平台移植的设计

 
阅读更多
现在手机越来越普及了,手机上能实现的功能也越来越多,很多人开始转入了手机上的应用开发,但是手机平台五花八门,如果想使开发出的程序具有较高的商业价值,就必须能够适应较多数的手机平台,要充分考虑程序的可移植性,本人接触手机应用开发已有近三年的时间,经历了许多种手机平台的开发,如基于symbian OS的S60系列、UIQ系列,基于windows CE的Pocket PC系列、SmartPhone系列,还有如MTK、ADI、Philips等,对于工程的设计深有感触,虽然经历了不少失败的教训,但收获也不小,这里把这几年的移植设计工作做一下总结,希望对于正在做移动应用开发的同业者有借鉴作用。在设计项目过程中主要要考虑如下几个要领:

1、选择易于移植的编程语言。当前在移动开发中使用的语言主流是J2ME和C语言,J2ME因为与平台无关,成为了首选的开发语言,但是用J2ME来开发,有些功能在某些手机平台上是无法实现的,有些手机平台根本就不支持J2ME的开发,所以我还是较倾向使用C语言,到目前为止,还没有碰到不支持C语言的,虽然有些平台要求用C++来开发,但C++还是对C语言兼容的,这里我们就是针对C语言来讲述如何开发易于移植的工程。

2、在程序架构设计上要针对使用异步函数的设计方法。调用某个函数,在函数退出时不能马上知道结果,必须通过获取系统返回的消息才能知道函数调用结果,这样的函数便是异步函数。所以在调用平台相关函数时要考虑到其可能是异步函数,可以设计一个事件或消息处理中心和一个超时处理方法,把有调用平台相关的函数,全部在那儿进行处理,便于简化处理流程。

3、对于基本数据类型和C语言基本标准函数要进行封装。大部份平台都会有一套不同的基本数据类型定义和函数功能一样但定义不同的C语言函数,特别是那些文件操作,基本上都不支持C语言中的函数方法定义,但实现的功能是一样的,所以可以通过宏定义或重定义进行封装。

4、最好有一套独立的内存管理程序。有些平台上的内存分配和释放函数的实现较简单,对于会产生较多内存碎片的程序可能会很快就无内存可用,有些平台上的一次能申请的最大内存可能无法满足程序的需要,这时候就需要自己设计一套内存管理程序。

5、代码设计时要考虑栈空间的大小。手机平台的程序可用栈空间一般都很小,一般不会超这8KB,函数的参数、局部变量、递归调用都是占用栈空间的,所以在手机平台中的系统函数很多都没有带参数,函数内局部变量当为数组变量时要注意数组长度,太长则容易造成栈溢出,一般不要超过128字节,要尽量少用递归函数或递归函数的递归层次要少,还有函数调用太深也是容易造成栈溢出的。

6、最好不要有全局变量。目前只知道symbian OS平台上应用程序不可以有全局变量(但可以有static const申明的全局常量),当然在symbian OS上要使用全局变量也是有方法的,不过,会有点麻烦,最好是不要有全局变量,如果确实需要全局变量,全局变量的数目应尽可能的少,并且要有一套对全局变量的统一管理方法。

7、要考虑到字节对齐问题。大部分手机是4字节对齐,所以在设计结构体数据类型时,结构体长度最好是4字节的倍数,数组的长度也最好是4字节的倍数,对于动态申请内存,最好不要申请小于4字节长度的内存,否则会浪费内存。

8、要尽量节约内存的使用。在手机平台中可用的内存一般是在几百KB左右,当然大部分智能手机(如symbian、windows CE手机)的内存能有几兆的空间,对于内存的使用要有一个很好的规划,在程序架构设计时就必须要考虑这方面的问题。

9、要考虑到字节顺序及字符集类型。大部分手机使用的字符集是UCS2字符,UCS2字符便有个高低字节顺序的问题,在处理UCS2字符时,如果发现处理后的字符乱掉了,那大部分原因是因为高低字节顺序错了,但对于UTF8字符是不用考虑字节顺序的,很多系统采用了UTF8字符便是基于这方面的考虑。

10、 循环运算次数不要太大。有些系统会对循环运算进行监视,如果循环次数太大并造成运算时间太长,系统会发生重启的现象。

11、 一次的不间断的处理过程时间不能太长。大部分低端的手机操作系统是单任务或抢占式多任务的,并且不支持多线程,如果某个不间断的处理过程时间太长,则手机会因在这个长过程中无法处理其它事件造成象死机的样子,这样子,程序的交互性便会很差,最好把一个大过程分成一个个运行时间较短的小过程,每个小过程由UI层进行控制,这样便可以及时响应和处理其它的事件。

12、文件操作不能太频繁。手机平台的系统资源有限,远不能跟PC相比,频繁地读写文件可能会造成系统应付不过来而瘫痪掉,要尽量减少特别是对文件的写入操作。

13、 与平台相关的接口设计要尽量简化。做移植主要工作量是在处理接口的设计上,接口设计得越简单,接口数目越少,移植的工作量则越少。

14、要设计好程序调试方法。在手机平台上进行程序调试是一个较麻烦的工作,有些手机平台会提供模拟器进行调试,但最后还是必须到手机上去调试,所以调试的方法很重要,必须要有一套独立的不依赖于平台的调试方法。

分享到:
评论

相关推荐

    如何开发易移植的Brew应用

    随着手机软件市场的不断扩大,越来越多的开发者们致力于移动应用的开发,本文简要论述了在BREW和J2ME平台下应用程序开发的特点和区别,并从接口和框架设计方面提出了易于进行平台移植的方法,以便于帮助那些准备将...

    安卓手机平台运行python程序的APP

    Pydroid 3是最易于使用和功能强大的教育的Python 3 IDE为Android。 特征: - 离线的Python 3.6解释:没有互联网才能运行Python程序。 - 全功能的终端仿真器,用readline的支持(PIP提供)。 - PIP包管理器和用于预置...

    嵌入式系统/ARM技术中的嵌入式机车车辆车载播放系统软件设计与实现

    系统使用Qt Creator作为开发工具,综合嵌入式数据库SQLite、开源多媒体播放器MPlayer技术,设计并实现了一个具有良好人机交互界面的嵌入式机车车辆车载播放系统,可对主流音视频文件进行播放,且系统易于移植和扩展...

    基于Android平台的车牌识别系统的研究

    在对Android平台的基础知识以的探究之下,根据前几章所提出的一系列车牌识别的系统步骤,本章将其移植到移动终端上来,实现了一个基于Android平台的车牌识别系统,通过对软件进行了功能测试和分析证明了该系统的有效...

    嵌入式机车车辆车载播放系统软件设计与实现

    系统使用Qt Creator作为开发工具,综合嵌入式数据库SQLite、开源多媒体播放器MPlayer技术,设计并实现了一个具有良好人机交互界面的嵌入式机车车辆车载播放系统,可对主流音视频文件进行播放,且系统易于移植和扩展...

    (完整word版)python3基础教程.doc

    Python 发展历史 Python 是由 Guido van Rossum 在八十年代末和九十年代初,在荷兰国家数学和计算机科学研究所设计出来的. Python 本身也是由诸多其他语言发展而来的,这包括 ABC、Modula-3、C、C++、Algol- 68、...

    蓝焰设计站图文管理系统

    新闻阅读:在其他页面中点击标题链接即进入新闻阅读页面,此时,每条新闻的详细信息将被取出,包括内容、标题、关键字等,并按照相对固定的格式放置在页面的不同区域,所有新闻使用大致相同的页面布局,只是各字段...

    基于S3C2440的多媒体控制器设计

    根据当今移动终端设备多功能、低功耗、易于移植的要求,分别从硬件和软件系统 2 方面提出了一种基于三星μS3C2440 芯片的嵌入式多媒体娱乐控制器的解决方案,同时介绍了利用 CLinux 构造嵌入式系统的方法,并提出了基于...

    单片机与DSP中的基于S3C2440的多媒体控制器设计

    根据当今移动终端设备多功能、低功耗、易于移植的要求,分别从硬件和软件系统 2 方面提出了一种基于三星μS3C2440 芯片的嵌入式多媒体娱乐控制器的解决方案,同时介绍了利用 CLinux 构造嵌入式系统的方法,并提出了基于...

    Unity中文基础教程

    Unity 是一款跨平台的游戏开发工具,从一开始就被设计成易于使用的产品。作为一个 完全集成的专业级应用, Unity 还包含了价值数百万美元的功能强大的游戏引擎。 Unity 3 作为一个游戏开发工具,它的设计主旨就是让...

    javapms门户网站源码

    在应用服务器平台兼容性方面,系统支持跨应用服务器,如Tomcat、Weblogic、Webspere、JBoss等应用服务器,很好的满足了各层次用户的需求。 在浏览器兼容性方面,目前多种浏览器并存,使用非IE浏览器的用户越来越多,...

    使用户快速实现 NFC 读/写器功能的近场通信参考-电路方案

    此参考设计提供了大量易于使用的应用编程接口 (API),可使用户快速实现 NFC 读/写器功能。随附的文档、硬件和示例 C 代码允许设计人员使用超低功耗 MSP430/MSP432 MCU 开发 NFC 读/写器应用或轻松移植到其他精心挑选...

    嵌入式红绿灯控制系统

    LED 灯具大多使用低压电源,因此在这类灯具的电路设计上,LED的串联个数在1-9 颗,尤以1-3 颗为常见。串联的总△VF 应低于电源Vin。如三颗LED 串联,△VF=3.4V X 3=10.2V。在Vin>12V,能正常工作。MR11、MR16射灯...

Global site tag (gtag.js) - Google Analytics