zoukankan      html  css  js  c++  java
  • 有序取出Map集合的元素

    最近写到一个程序,返回了map,但是经过查阅资料,map是没有顺序的,各种查阅资料无果,最后自己写了这个方法。。

    1,通过map集合的keySet()方法,获取到一个包含map所有key的Set集合

    2,定义一个新的TreeSet集合(TreeSet集合有自动排序功能)

    3,将第一步得到的Set集合遍历赋给TreeSet集合,这样所有key都排好序并保存在TreeSet里面

    4,然后通过TreeSet的迭代器遍历,并同时根据迭代器返回的key,一个一个取出map里面的value

    ----------------------------------------------------------------代码示例------------------------------------------------------------------------------

    Map<Integer, String> oldMap=new HashMap<Integer,String>();//待排序的map集合
    Map<Integer, String> newMap=new HashMap<Integer,String>();//排序后的map集合
    Set<Integer> keySet = oldMap.keySet();//存放key的set集合
    TreeSet<Integer> keyTreeSet = new TreeSet<Integer>();//存放key排序后的set集合
    Iterator<Integer> itKeySet;//Set集合的迭代器
    Iterator<Integer> itKeyTreeSet;//TreeSet集合的迭代器

      //放入一些测试数据   oldMap.put(1, "content1"); oldMap.put(5, "content5"); oldMap.put(6, "content6"); oldMap.put(10, "content10"); oldMap.put(11, "content11"); oldMap.put(100, "content100"); oldMap.put(999, "content999"); keySet=oldMap.keySet();//获取map的所有key itKeySet=keySet.iterator(); while (itKeySet.hasNext()) {   Integer key = (Integer) itKeySet.next();   System.out.print(key+" ");//打印排序前key的顺序     keyTreeSet.add(key); } System.out.println("\n"); itKeyTreeSet=keyTreeSet.iterator(); while (itKeyTreeSet.hasNext()) {   Integer key = (Integer) itKeyTreeSet.next();   System.out.print(key+" ");//打印一下排序后key的顺序     newMap.put(key, oldMap.get(key));//此时根据排序好的TreeSet挨个取出Map里面的value,此处我只是放到了一个newMap中 }

     

    打印key结果如下所示

  • 相关阅读:
    MC9S12 硬件设计
    ESD
    选用与使用稳压二极管的介绍
    MOSFET 栅极电阻作用及其选型
    orcad常用库文件介绍
    开关电源和LDO的区别
    续流二极管的作用及选型
    为什么大电容滤低频小电容滤高频的问题
    Java常用API——时间类
    Idea问题:“marketplace plugins are not loaded”解决方案
  • 原文地址:https://www.cnblogs.com/convict/p/8318352.html
Copyright © 2011-2022 走看看