Java TreeMap按照key排序

Posted BandaYung

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java TreeMap按照key排序相关的知识,希望对你有一定的参考价值。

TreeMap能够把它保存的记录根据键排序,默认是按升序排序,也可以指定排序的比较器。当用Iterator遍历TreeMap时,得到的记录是排过序的。TreeMap 和 HashMap 用法大致相同,但实际需求中,我们需要把一些数据进行排序;

以前在项目中,从数据库查询出来的数据放在List中,顺序都还是对的,但放在HashMap中,顺序就完全乱了。

为了处理排序的问题:
 

   1.对于一些简单的排序,如:数字,英文字母等

 

      TreeMap hm = new TreeMap<String, String>(new Comparator() 
               public int compare(Object o1, Object o2) 
                      //如果有空值,直接返回0
                      if (o1 == null || o2 == null)
                          return 0; 
                    
                     return String.valueOf(o1).compareTo(String.valueOf(o2));
               
      );

备注: 

 

      compareTo(String str) :是String 提供的一个方法,如果参数字符串等于此字符串,
                 则返回 0 值;如果按字典顺序此字符串小于字符串参数,则返回一个小于 0 的值;
                 如果按字典顺序此字符串大于字符串参数,则返回一个大于 0 的值。

       int compare(T o1,T o2):随第一个参数小于、等于或大于第二个参数而分别返回负整数、
                                   零或正整数。

 

    2.对于处理有中文排序的问题

  TreeMap hm = new TreeMap<String, String>(new Comparator() 
          public int compare(Object o1, Object o2) 
               //如果有空值,直接返回0
                if (o1 == null || o2 == null)
                      return 0; 
                    
              CollationKey ck1 = collator.getCollationKey(String.valueOf(o1));
              CollationKey ck2 = collator.getCollationKey(String.valueOf(o2));
              return ck1.compareTo(ck2);              
        
   );

备注:CollationKey:CollationKey 表示遵守特定 Collator 对象规则的 String。

          比较两个CollationKey 将返回它们所表示的 String 的相对顺序。使用 CollationKey
         来比较 String 通常比使用 Collator.compare 更快。因此,当必须多次比较 String 时
          (例如,对一个 String 列表进行排序),使用 CollationKey 会更高效。

 实例:

import java.util.Collection;
import java.util.Iterator;
import java.util.SortedMap;
import java.util.TreeMap;

public class TestSort 
public static void main(String[] args) 
    // TODO Auto-generated method stub    
    CollatorComparator comparator = new CollatorComparator();
    TreeMap map = new TreeMap(comparator);      
    for(int i=0; i<10; i++) 
        String s = ""+(int)(Math.random()*1000);
        map.put(s,s);
    
    map.put("abcd","abcd");
    map.put("Abc", "Abc");
    map.put("bbb","bbb");
    map.put("BBBB", "BBBB");
    map.put("北京","北京");
    map.put("中国","中国");
    map.put("上海", "上海");
    map.put("厦门", "厦门");
    map.put("香港", "香港");
    map.put("碑海", "碑海");
    Collection col = map.values();
    Iterator it = col.iterator();
    while(it.hasNext()) 
        System.out.println(it.next());
    
  

比较器类:

 

import java.text.CollationKey;
import java.text.Collator;
import java.util.Comparator;

public class CollatorComparator implements Comparator 
Collator collator = Collator.getInstance();
public int compare(Object element1, Object element2) 
    CollationKey key1 = collator.getCollationKey(element1.toString());
    CollationKey key2 = collator.getCollationKey(element2.toString());
    return key1.compareTo(key2);

运行该类,运行结果如下:

325
62
653
72
730
757
874
895
909
921
碑海
北京
上海
厦门
香港
中国
Abc
abcd
bbb
BBBB

此时可以看到中文的排序已经完成正常。如果想不让英文区分大小写,则修改CollatorComparator类,找到 element1.toString()

修改为:
   element1.toString().toLowerCase()

当然你改成转换成大写的也无所谓了,当然element2.toString()也要同时修改为element2.toString().toLowerCase()。

转载:http://blog.sina.com.cn/s/blog_530fe9870100l5oy.html





 

以上是关于Java TreeMap按照key排序的主要内容,如果未能解决你的问题,请参考以下文章

如何决定使用 HashMap 还是 TreeMap?

如何决定使用 HashMap 还是 TreeMap?

TreeMap按照key排序

TreeMap按照key排序

java map

TreeMap按照value进行排序