zoukankan      html  css  js  c++  java
  • 转:Java Map 排序定义

    1、一般的map定义:
    Map<Key, Object> map = new HashMap<Key, Object>();
    这种map的定义,里面的数据是乱序的,没有顺序规则可依;

    2、保持有序的map定义:
    Map<Key, Object> map = new LinkedHashMap<Key, Object>();
    链表结构的HashMap,是有序的,put进去的数据顺序是怎样,出来的顺序也是那样,不会打乱里面数据的顺序;
    但是需要注意的一点是:如果put进去的key是存在相同值的话, 用LinkedHashMap是会乱序的,而且出来的数据也不对,对于重复值的存储,最好先合并重复的key,再将相应的key和object放进去。

    3、自定义顺序的map定义:
    Map<Key, Object> map = new TreeMap<Key, Object>();
    这种map的顺序可自定制,例如倒序:
    Map<Key, Object> map = new TreeMap<Key, Object>();
    map.descendingKeySet();

    附Map遍历方法:
    /* 第一种: entryset只遍历一次:它把key和value放到entry */
    Map map = getMap();
    Iterator iter = map.entrySet().iterator();
    while (iter.hasNext()) {
        Map.Entry entry = (Map.Entry) iter.next();
        Object key = entry.getKey();
        Object val = entry.getValue();
    }//高效,使用此种方式

    /* 第二种: keySet实际遍历了2次:
    转为iterator时候一次;
    取key对应value又一次。*/
    Map map = getMap();
    Iterator iter = map.keySet().iterator();
    while (iter.hasNext()) {
        Object key = iter.next();
        Object val = map.get(key);
    }//效率低

  • 相关阅读:
    查找第一个不重复的字符问题
    gops
    关于 Go 中 Map 类型和 Slice 类型的传递
    Go 程序的性能优化及 pprof 的使用
    Go语言标准库_输入/输出
    Linux 终端 Bash 常用快捷键介绍及经验
    蓄水池采样算法(Reservoir Sampling)
    Guice 依赖绑定
    基本动态规划之硬币问题
    程序打包成jar 获取不到工程目录下文件的问题
  • 原文地址:https://www.cnblogs.com/zhangdongdong/p/3035061.html
Copyright © 2011-2022 走看看