利用J2ME里的RMS对记录进行排序

本文介绍了J2ME中RMS如何通过实现RecordComparator接口来对记录进行排序,并提供了一个具体的实现示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

偶然在网上看到有人问:如何利用RMS对其内的积分进行排序。恰巧最近在总结、沉淀一些工作中的积累,于是就有了这篇文章。

J2ME里RMS对记录进行排序的方法,是借鉴了J2SE里的colletcion框架的处理方法而来的。

我们知道如果Collection框架中的实现类要对其内的Object元素进行排序,要调用Sort()方法,但是其内的Object元素必须要实现Comparable接口。

class Student implements Comaparable{
int num;
String name;

Student(int num,String name){
this.num = num;
this.name = name;
}

public int compareTo(Object o){
Student s = (Student)o;
return num>s.num?1:(num==s.num?0:-1);
}
}

如上面这个student类,如果将其做为Object元素添加到collection实现类中,再调用Sort()方法。将按照compareTo()中的方法对元素进行排序。

在RMS里也是同样的实现机制,要对RMS里的记录进行排序,则应该对相应的RMS调用enumerateRecords(null,comparator,false);这个方法的中间一个参数就是相应的比较器。这个方法返回一个RecordEnumeration对象,RecordEnumeration内存放的就是排序后的记录。

一个典型的RecordComparator实现如下:

RecordComparator comparator = new RecordComparator() {
public int compare(byte[] first, byte[] second) {
try {
DataInputStream isFirst=new DataInputStream(new ByteArrayInputStream(first));
DataInputStream isSecond=new DataInputStream(new ByteArrayInputStream(second));
String firstName = isFirst.readUTF();
int firstScore = isFirst.readInt();
String secondName = isSecond.readUTF();
int secondScore = isSecond.readInt();
if(firstScore != secondScore) {
return firstScore > secondScore ? RecordComparator.PRECEDES : RecordComparator.FOLLOWS;
}
int comp = firstName.compareTo(secondName);
if(comp == 0) {
return RecordComparator.EQUIVALENT;
} else if(comp < 0) {
return RecordComparator.PRECEDES;
} else {
return RecordComparator.FOLLOWS;
}
} catch(IOException e) {
return RecordComparator.EQUIVALENT;

}
}
};

只需要把这个RecordComparator传递到相应的RMS里,即可对其中的记录进行排序。然后可以根据自己的需要取出其中的前几条或后几条记录。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值