JAVA集合按照中文排序

package ChineseSort;
 

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) {

    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());

    }
  }
}

 

public class CollatorComparator implements Comparator {

  Collator collator = Collator.getInstance();
 
  public int compare(Object element1, Object element2) {
   
    CollationKey key1 = collator.getCollationKey(element1.toString().toLowerCase());
    CollationKey key2 = collator.getCollationKey(element2.toString().toLowerCase());

    return key1.compareTo(key2);
  }
}


    现在可以看到,排序已经完全符合我们的要求了。如果要反向排序也很容易,遍历的时候倒过来,或者你写两个Comparator的实现类,正向的排序就像我们前面所写的,反向排序就将return key1.compareTo(key2);修改成return -key1.compareTo(key2);,加了个负号,这里你可以直接加个符号看看效果,结果我就不写了,肯定中国是Number One。我还真没找到TreeMap里直接反向的方法,谁看到了告诉我。

    最后一些要说明的,这里我就不再写实现的代码了,就是我们要实现的是根据model中的一个列进行排序,而我们测试代码只是简单的一些值,这个容易,遍历 所有model,把要排序的列值取出来作为TreeMap的key,然后model放进去作为value就行了,这个很简单,如果想写成稍微通用点的,就 使用反射机制,把取值方法封装一下就行了,然后把model对象和方法名扔进去就行了。至于value值重复的问题,也好办,只要value相同只要不是 多列同时作为排序的键,那么他们之间的前后顺序无所谓,判断一下当前Map中是否含有该key值,存在,则新的key做成value+longtime就 行了,就是加个时间戳(感觉用时间戳比较方便,其它的能区分的办法也行啦)。至于多列的排序,其实也容易,按照列的前后顺序 firstvalue+secondvalue+......组成key放到TreeMap里照样OK

你可能感兴趣的:(java集合)