本文主要介绍j2me的基本概念。因为注意到国内的java站点介绍j2me的还比较少,所以就写了本文。如果有什么不妥的地方,欢迎您email我,讨论商榷。
如您要转贴,请保留原出处,并勿做删改。谢谢。
1.名词
这里我列出一些常见的关键词,方便与下文参照.具体解释见后文.
j2me(java2 platform, micro edition)
cldc(connected, limited device configuration)
midp(mobile information device profile)
kvm(the k virtual machine)
2.背景
随着无线应用与嵌入式系统的愈来愈受到人们的重视,sun也推出了j2me来迎合这一趋势.(实际上道也不能算是新推出,熟悉java历史的人都知道,java原先本是为了开发消费性电子产品而研制的.谁知,无心插柳柳成荫,因在网络应用上的出色表现而流行,以致现在的j2ee、ejb等等,发展地越来越庞大。这次实质是杀了个回马枪。至于表现如何,还得拭目以待)sun认为,未来的信息设备将比我们今天的更为customizable 和 personal。这一点我们已经可以从手机和pda的流行程度看出。所以为了开发面向这些设备的applications。sun推出了j2me(java2 platform, micro edition)。
3.j2me的基本结构
j2me把设备分为两类,一种是联接设备( connected device),一种是有限联接设备(connected, limited device)。前一种对应于那些有电源的,电力充裕,较大的设备。例如:电视机,冰箱等,后一种对应于主要使用电池,小型的设备,例如:手机,pda等。这里我只涉及第二种,有限联接设备(connected, limited device)。
3.j2me的基本结构
sun把j2me分为两个部分:configuration 和 profile。
configuration包括虚拟机(virtual machine),核心的类库与api。configuration层定义一个java虚拟机的特性与java类库的最小子集。也就是说,configuration层提供了开发人员一个最基础,最核心的java平台。就像我前文提到的,j2me把设备分为两类,一种是联接 设备(connected device),一种是有限联接设备(connected, limited device)。对应这两种设备就有了两种j2me configuration。分别为cdc(connected device con-figuration )和cldc(connected, limited device configuration)。这里请注意,cdc使用经典的javavm,而cldc使用的是kvm(the k virtual machine)。
注:kvm是sun为使用16/32位risc/cisc微处理器或控制器,并其可用内存为160kb~512kb 的的设备而开发的。
profile层也包含一组api,主要针对于特定的某一族系的设备而定义。profile层在特定的configuration层上实现,而我们程序员则负责在特定的profile上编写应用程序。对于手机,pda等connected, limited device。它们的profile层称为midp(mobile informationdevice profile)。于是midp与cldc合在一起就构成了一个完整的j2me架构。
顺便说一句,对于midp上的应用程序sun也有独特的叫法,它们被称为midlet。你是不是觉得有点眼熟。想想java中的applet。
┌───────┐┄┄┄┄┄┄┄
│midlet │ 应用程序
├───────┤┈┈┈┈┈┈┈
│ midp │ proflie层
├───────┤┄┄┄┄┄┄┄
│j2me核心api │ configuration层
├───────┤ cldc
│ kvm │
├───────┤┈┄┄┄┄┄┄
│特定的硬件 │
└───────┘
图1 j2me的cldc&midp架构
4。深入理解cldc
本节的部分内容译自j2me white paper,比较枯燥,但请记住,毕竟,正确的观念重于一切。
cldc的目的
·为小型的,且资源有限,connected limited的设备定义一个标准的java平台。
·允许动态的向这些设备发布内容与应用程序。
·方便第三方软件厂商与开发者向这些设备移植内容与应用程序。
cldc的范围
·java语言与虚拟机的特性
·核心java类库(如java.lang.*, java.util.*)
·输入/输出
·对网络的支持
·对安全性的支持
·对国际化的支持
cldc不包括的范围(即由midp解决的)
·对应用程序life-cycle的管理(就是指一个应用程序是如何安装,运行,删除的)
·ui界面(user interface)
·event处理
·高级应用程序模式(这里指用户与应用程序的交互)。
cldc的安全性
低端的基于虚拟机的安全性由下载时对class文件的审核(verification)步骤来保证。(如果你写过并编译过midlet程序,就会知道这一步是必须的。这里有一个概念就行了,我会在以后讲述如何创建midlet程序时,详细介绍具体的步骤)。
基于应用程序的安全性通过使每个应用程序分别运行在相对独立的封闭环境中来保证并且处于被保护的系统package中的类不能被应用程序重载(overridded)。
对于java语言支持的特殊的方面
cldc总的来说是与java语言完全兼容的,但需注意以下几点:
不支持浮点数据类型(即没有float和double)(这实际上主要是由于cldc所面向的设备,其硬件因其内存限制或是基于安全性的考虑不支持浮点运算)
不支持类实例(class instance)的终结(finalization),即不存object.finalize ()方法。(注:finalization指的是java中提供的有别与garbage collection的另外的一种对象清理方法。具体可参看侯捷老师译的bruce eckel的《thinking in java 第二版》,可以在www.jjhou.com中下载)
有限的错误处理,即大部分java.lang.error的子类都未被支持。与此相反,cldc包括了相当完备的异常(exception)类。
对于java虚拟机(java virtual machine)支持的特殊的方面
实质上cldc在其严格的内存限制下达到了对java虚拟机相当程度的兼容性。不过还是有下列不同点。
·不支持浮点数据类型(没有float和double)
·不支持jni (the java native interface )
·不支持用户自定义的java级的类载入器(class loaders )
·没有反射(reflection)特性(注:reflection指java通过java.lang.reflect提供的,可以对类的能力进行分析的功能。常用来对类的结构进行检查,在javabeans上有广泛运用可参见gary cornell的core java2 volumei,ii,机工有出中译本)
·不支持线程组(thread groups)或守护线程(daemon threads)
·不支持类实例(class instance)的终结(finalization)
·没有弱参考(weak references)(注:weak reference提供了一种解决指向已经被garbage collector清除的对象的方法。在java2中被介绍。具体请参考java.lang.ref api文档,和sun网站上关于reference objects和garbage collection的文章。)
·有限的错误处理(error handling)
4。深入理解cldc (part ii)
本节的部分内容译自j2me white paper,比较枯燥,但请记住,毕竟,正确的观念重于一切。
类文件审核过程(classfiles verification)
cldc要求其下层的虚拟机能够辨别并拒绝非法的class文件。但由于cldc本身面向小内存消耗的小型设备这一前提。其类文件检测机制与j2se中定义的标准类文件审核机制还有所不同。请注意看下图:
myapp.java
│
↓
┌───┐
│javac │┄编译器
└───┘
↓
myapp.class
↓
┌──────┐
│preverifier │┈预审核器
└──────┘
↓
myapp.class
│
↓download…
┌────────┒
│ ┠┄┄kvm运行环境
│┌──────┐┃ (目标设备)
││ verifier │┃
│└──────┘┃
│ ┃
│┌──────┐┃
││ │┃
││interpreter │┃
││ │┃
│└──────┘┃
┕━━━━━━━━┛
图2 cldc/kvm中类文件的审核过程
请注意cldc中的预审核(preverification)过程。这是cldc区别于通常的类文件审核过程的关键。如上图所示,当源程序被编译后,必须被预审核器预审核,然后才能被下载到目标设备上去。之所以有这一步骤,主要是为了减轻kvm中审核器的负担,加快审核速度。就像我前文提到的,这是出于对cldc支持的硬件的考虑(毕竟手机和pda并没有我们pc机那样奔腾的“芯”呀!^-^)。这里记住这个概念就行了。具体的操作方法我会在以后讲述编写midlet程序时介绍。
类文件格式
sun要求通过jar(compressed java archive)给java应用程序打包,这里也不例外。所以如果你想把你的midlet程序下载到设备上运行,你就得先用jar打包。具体的操作方法我会在以后讲述编写midlet程序时介绍。
cldc的类库
如果不严格的说,cldc的类库是j2se的一个小的子集,有以下这种近似关系成立,即j2se包含cdc包含cldc。但要注意cldc并未完全包含于j2se,它还包括一 些专门针对无线设施的类。所以可以把cldc的类库简要划分为两部分:从j2se继承的类和cldc专有的类。
(1)从j2se继承的类
这部分包括三个package,即java.lang,java.util和java.io。注意即使这些从j2se继承的的类,也是大大“缩了水”的。例如java.util的类与接口由j2se的47个缩减到10个。另外两个也有相应缩减。
系统类
from java.lang:
object, class, runtime, system, thread, runnable,
string, stringbuffer, throwable
数据类型类
from java.lang:
boolean, byte, short, integer, long, character
容器类(container class)
from java.util:
vector, stack, hashtable, enumeration
i/o 类
from java.io:
inputstream, outputstream, bytearrayinputstream,
bytearrayoutputstream, datainput, dataoutput,
datainputstream, dataoutputstream, reader, writer,
inputstreamreader, outputstreamwriter, printstream
日期与时间类
from java.util:
calendar, date, timezone
附加的实用类
java.util.random, java.lang.math
异常类(exception classes)
from java.lang:
exception, classnotfoundexception,
illegalaccessexception, instantiationexception,
interruptedexception, runtimeexception,
arithmeticexception, arraystoreexception,
classcastexception, illegalargumentexception,
illegalthreadstateexception, numberformatexception,
illegalmonitorstateexception, indexoutofboundsexception,
arrayindexoutofboundsexception,
stringindexoutofboundsexception,
negativearraysizeexception, nullpointerexception,
securityexception
from java.util:
emptystackexception, nosuchelementexception
from java.io:
eofexception, ioexception, interruptedexception,
unsupportedencodingexception, utfdataformatexception
错误类
from java.lang:
error, virtualmachineerror, outofmemoryerror
(2)cldc专有的类
这里sun提供了javax.microedition.io包。用它来提供与外界沟通的桥梁。(注:就像在j2se中我们利用java.net.*)注意,所有的连接都由javax.microedition.connector创建。例如:你可以打开一个http连接通过 connector.open("http://www.chinajavaworld.com")
javax.microedition.io的接口包括:
connection, inputconnection, outputconnection,
streamconnection, contentconnection, datagramconnection,
streamconnectionnotifier
这里再说明一点,实际上你也可以看出,cldc所包括的类库,并不足以开发应用程序。例如,没有ui界面的支持等。这也正是cldc的设计理念。cldc本身就从未想过要解决所有的问题。这些问题要靠其上层的profile-midp来解决。例如javax.microedition.lcdui就是定义在midp中的ui包。
