Fang.W
我也是江湖中人,但没有武功,比的是技术!——21世纪的江湖人

      今天来讲一讲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<num/2);) {
    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 阅读(932) 评论(0)  编辑  收藏 所属分类: J2ME

只有注册用户登录后才能发表评论。


网站导航: