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里,即可对其中的记录进行排序。然后可以根据自己的需要取出其中的前几条或后几条记录。