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

        偶然在网上看到有人问:如何利用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里,即可对其中的记录进行排序。然后可以根据自己的需要取出其中的前几条或后几条记录。



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


你可能感兴趣的:(j2me)