`
happmaoo
  • 浏览: 4331745 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

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

阅读更多
<iframe align="top" marginwidth="0" marginheight="0" src="http://www.zealware.com/csdnblog01.html" frameborder="0" width="728" scrolling="no" height="90"></iframe>

偶然在网上看到有人问:如何利用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 return RecordComparator.PRECEDES;
} else {
return RecordComparator.FOLLOWS;
}
} catch(IOException e) {
return RecordComparator.EQUIVALENT;

}
}
};

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



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=862443


分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics