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 会更高效。

实例:

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) {
// 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());}}} 比较器类:
package ChineseSort;
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()。

最新文章

  1. tomcat之一:指定tomcat运行时JDK版本
  2. CSS3与页面布局学习笔记(八)——浏览器兼容性问题与前端性能优化方案
  3. [C#6] 0-概览
  4. Web API应用架构在Winform混合框架中的应用(5)--系统级别字典和公司级别字典并存的处理方式
  5. ui router 介绍
  6. Error #include nested too deeply
  7. Cassandra 技术选型的问题
  8. XtraBackup原理3
  9. 图片上传并显示(兼容ie),图片大小判断
  10. 从PowerDesigner概念设计模型(CDM)中的3种实体关系说起
  11. debian linux 中如何查看软件包是否已经安装和如何安装、卸载软件
  12. [Hapi.js] View engines
  13. Android App 内存泄漏Handler
  14. 浅谈JavaScript时间与正则表达式
  15. 修改MySQL数据库密码
  16. Vue使用Echarts以及Echarts配置分享
  17. html-webpack-plugin插件使用chunks属性时报错
  18. ios中设置input为readonly后,解决弹起软键盘的问题
  19. ckeditor富文本编辑器的基本配置设置:
  20. Axure 验证码、进度条、分页条(翻页)、搜索框、选项卡

热门文章

  1. linux误删数据恢复
  2. php项目有负载,$_SERVER[&#39;HTTP_X_FORWARDED_FOR&#39;]函数在不同系统中获取到的值形式不一样,ios系统苹果手机只能获取到一个ip(113.87.214.xxx),而安卓手机获取到的是2个ip中间逗号隔开的形式(113.87.214.xxx , xxx.xxx.xxx.xxx)
  3. linux 下apache 停止、重启等操作
  4. Markdown初步使用
  5. TCP/IP网络编程系列之二(初级)
  6. eclipse 创建一个java项目 运行
  7. python接口自动化22-签名(signature)鉴权(authentication)之加密(HEX、MD5、HMAC-SHA256)
  8. 【转】用JMeter来测试Tomcat的性能
  9. Idea项目:Failed to create a Maven project ‘…pom.xml’ already exists in VFS 解决
  10. Vim编辑器基本操作学习(一)