博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
J2ME编程最佳实践之灵活的RMS应用
阅读量:4044 次
发布时间:2019-05-24

本文共 2356 字,大约阅读时间需要 7 分钟。

midp应用程序的标准持久化方案就是使用rms。rms类似于一个小型数据库,recordstore相当于数据库的表,每个“表”由若干记录(record)构成,一条记录就是一个用int表示的记录号recordid和用byte[]表示的内容。记录号可以看作是“主键”,byte[]数组存储内容。

  rms提供的记录操作可以实现根据id直接获得记录,或者枚举出一个表中的所有记录。

  枚举记录是非常低效的,因为只能比较byte[]数据来确定该记录是否是所需的记录。通过id获得记录是高效而方便的,类似于sql语句“select bytearraydata from recordstorename where recordid=?”。然而,通常应用程序很难知道某条记录的id号,而rms记录的“主键”又仅限于int类型,无法使用其他类型如string作为“主键”来查找。因此,对于需要存取不同类型对象的应用程序而言,就需要一个灵活的rms操作框架。

  我们的基本设想是,如果能使用string作为“主键”来查找记录,就能非常方便地获得所需的内容。例如,应用程序设置可以通过"sys.settings"获得byte[]数组,并依次读取出设置,用户登录信息可以通过"user.info"获得byte[]数组,再分解出用户名和口令。

  因此,我们实现一个storagehandler类,提供唯一的rms访问接口,使得其他类完全不必考虑底层的rms操作,只需提供能标识自身的一个string即可。

  如果我们能实现一种类似于数据库索引的查找表,就能根据string关键字查找某条记录。因此,我们使用一个名为"index"的recordstore来存储所有的索引,每一条索引都指向某一条具体记录的id,设计一个indexentry表示一条索引:

class indexentry {
private int selfid; // indexentry的id
private int recordid; // 对应记录的id
private string key; // 访问记录的key
}

  根据索引查找,分3步进行:

  1.在名为"index"的recordstore中根据string查找对应的indexentry。

   2.取出indexentry,获得记录id号。
   3.根据id号获得另一个recordstore的记录,然后就可以读取、更新和删除该记录。

  如下图所示:

  由于indexentry保存的数据很少,为了加快查找速度,可以在应用程序启动时,把所有的indexentry读入一个vector,在后面的操作中更新这个vector并与recordstore保持同步。

  为了处理不同类型的数据,所有可通过storagehandler存取的类都必须实现一个storable接口:

public interface storable {
string getkey();
void getdata(dataoutputstream output) throws ioexception;
void setdata(datainputstream input) throws ioexception;
}

  前面已经提到,在midp应用程序中,序列化一个类的最佳方法是使用datainputstream和dataoutputstream。因此,需要持久化的类可以通过getdata()和setdata()方法非常方便地存取。假定应用程序的类userinfo保存了用户的登录名、口令和是否自动登录的信息:

public class userinfo {
string username;
string password;
boolean autologin;
}

  为了能将userinfo存入rms,需要实现storable接口:

class userinfo implements storable {
string username;
string password;
boolean autologin;
public string getkey() { return "user.info"; } // 提供一个唯一标识符即可
public void getdata(dataoutputstream output) throws ioexception {
output.writeutf(username);
output.writeutf(password);
output.writeboolean(autologin);
}
public void setdata(datainputstream input) throws ioexception {
username = input.readutf();
password = input.readutf();
autologin = input.readboolean();
}
// getters here...
}

  要保存userinfo,只需调用storagehandler的保存方法:

storagehandler.storeorupdate(userinfo);

  要读取userinfo,调用storagehandler的读取方法:

userinfo userinfo = new userinfo();
storagehandler.load(userinfo);

  这样,需要读取或保存数据的类完全不必涉及底层的rms操作,大大简化了应用程序的设计,增强了源代码的可复用性与可维护性。

转载地址:http://ededi.baihongyu.com/

你可能感兴趣的文章
linux sfdisk partition
查看>>
ipconfig,ifconfig,iwconfig
查看>>
opensuse12.2 PL2303 minicom
查看>>
网络视频服务器移植
查看>>
Encoding Schemes
查看>>
移植QT
查看>>
如此调用
查看>>
计算机的发展史
查看>>
带WiringPi库的交叉编译如何处理一
查看>>
带WiringPi库的交叉笔译如何处理二之软链接概念
查看>>
Spring事务的七种传播行为
查看>>
ES写入找不到主节点问题排查
查看>>
Java8 HashMap集合解析
查看>>
欢迎使用CSDN-markdown编辑器
查看>>
Android计算器实现源码分析
查看>>
Android系统构架
查看>>
Android 跨应用程序访问窗口知识点总结
查看>>
各种排序算法的分析及java实现
查看>>
SSH框架总结(框架分析+环境搭建+实例源码下载)
查看>>
js弹窗插件
查看>>