java rms是什么意思,关于RMS的使用

本文介绍了J2ME中用于手机数据存储的记录管理系统(RMS),它是一个简单的面向记录的数据库模型。记录存储可以看作是“表”,记录则相当于“表”中的数据。RMS提供了一种线性存储的方式,不同于PC上的二维数据库。通过示例代码展示了如何使用RMS存储和读取游戏最高分,强调了如何获取下一个可用记录ID以避免访问已删除记录时的异常。
摘要由CSDN通过智能技术生成

今天来讲一讲RMS。纯粹是在做项目过程中自己的一些领悟总结,如果有不正确的地方,请高人们指点。

在PC中我们可以将数据存在数据库中进行管理。那么在手机上,我们将数据存在哪里呢,又是怎样管理这些数据的呢?

手机系统为每一个MIDlet都开辟了存储空间用来存储程序数据,并且有专门的管理系统来管理这个存储空间。当然它只是一个简单的管理系统,不可能像PC上那样的数据库管理工具。我们称这个系统为“记录管理系统(RMS)”,它是一个简单的面向记录的数据库模型。

来看看一些名词:

(1)记录存储:在一个程序中,你可以开辟n个记录存储,为每一个“存储”指定唯一的名字。它就相当于我们常说的“表”。

(2)记录:每个记录存储中包含着n个记录。即“表”中的每一个数据。

注意:虽然我们可以将“记录存储”与“表”一起联想,但是它们的结构有很多的不同。“表”是二维的,对应着行和列。而“记录存储”是一维的,所有记录都是线性存放的。

来看一段程序,演示了如何使用RMS来存储程序中的数据,比如存取游戏最高分。

RecordStore rs;

//存数据

public boolean newDate(String scorce, String name) {

byte[] byt;

try {

//指定记录存储的Name

String storeName = "HighScorces";

//打开该存储,如果不存在,就新建。

rs = RecordStore.openRecordStore(storeName, true);

//添加一个记录: scorce

byt = scorce.getBytes();

rs.addRecord(byt, 0, byt.length);

//添加一个记录:name

byt = name.getBytes("UTF-8");

rs.addRecord(byt, 0, byt.length);

//关闭该记录存储

rs.closeRecordStore();

} catch (Exception e) {

System.out.println("save false!");

return false;

}

return true;

}

//读数据

public String[] getData(int type, boolean flg) {

String[] strs = null;

try {

String storeName = "HighScorces";

rs = RecordStore.openRecordStore(storeName, true);

//获取该存储中的记录总数

int num = rs.getNumRecords();

//获取下一个可用记录ID

int recordID = rs.getNextRecordID();

//

strs = new String[num / 2];

byte[] bytes;

for (int i = 0, j = 0; (i < recordID - 1)&&(j

i += 2;

try {

if (flg) {

//读取name

bytes = rs.getRecord(i);

} else {

//读取scorce

bytes = rs.getRecord(i-1);

}

strs[j] = new String(bytes,"UTF-8");

j++;

} catch (InvalidRecordIDException ide) {

//记录不存在,检查下一个记录ID

continue;

}

}

rs.closeRecordStore();

} catch (RecordStoreException e) {

System.out.println("no data!");

strs = null;

}catch (IOException ie){

System.out.println("IOException!");

strs = null;

}

return strs;

}

在这里解释一下,为什么要用 int recordID = rs.getNextRecordID(); 来获取下一个可用记录ID?

在RecordStore中每一个record都会被分配一个ID,且该ID是从1开始的。最重要的是每个被使用过的ID是不能被重新分配的。即:当我们用 deleteRecord(int recordId) 删除一个记录后,该记录的ID仍然不能被其他记录使用,也就是该ID所指向的记录是不存在的。因此,如果你用该ID去访问记录时,系统会抛出异常。但是,记录的总数为实际存在的所有记录的数目。所以我们可以通过获取下一个可用记录ID来进行相关操作。

记录存储是由系统平台来维护的,一般是不会丢失的。记录存储的生成位置也是由平台决定的,并不会暴露给MIDlet。 MIDlet只依赖与记录存储的名字来访问该记录存储。当一个MIDlet组件从系统删除时,所有与此MIDlet有关的存储记录都会被系统自动删除。

posted on 2007-07-30 13:50 Fang.W 阅读(950) 评论(0)  编辑  收藏 所属分类: J2ME

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值