Map集合循环 遍历 及 排序

遍历

第一种:通过Map.keySet()遍历key和value

Map map = new HashMap();
map.put("aaa", 111);
map.put("bbb", 222);
map.put("ccc", 333);
map.put("ddd", 444);
System.out.println("第一种:通过Map.keySet()遍历key和value:");

//keySet获取map集合key的集合  然后在遍历key即可
for(String key:map.keySet()){
    String value = map.get(key).toString();//
    System.out.println("key:"+key+" vlaue:"+value);
}

第二种:通过Map.entrySet使用iterator遍历key和value

Iterator> it = map.entrySet().iterator();
while(it.hasNext()){
    Entry entry = it.next();
    System.out.println("key:"+entry.getKey()+"  key:"+entry.getValue());
}

第三种:通过Map.entrySet遍历key和value ( 数据量大时推荐使用)

for (Map.Entry m : map.entrySet()) {
    System.out.println("key:" + m.getKey() + " value:" + m.getValue());
}

第四种:通过Map.values()遍历所有的value,但不能遍历key

for(Object m:map.values()){
    System.out.println(m);
}

 

排序

Map tm=new TreeMap();
tm.put("a", "ddd");
tm.put("b", "ccc");
tm.put("c", "bbb");
tm.put("d", "aaa");
//这里将map.entrySet()转换成list
List> list = new ArrayList>(tm.entrySet());
//然后通过比较器来实现排序
Collections.sort(list,new Comparator>() {
    //降序排序
    @Override
    public int compare(Entry o1,
        Entry o2) {
        return o2.getValue().compareTo(o1.getValue());
    }
});

for(Map.Entry mapping:list){ 
    System.out.println(mapping.getKey()+":"+mapping.getValue()); 
} 

 

你可能感兴趣的:(Map集合循环 遍历 及 排序)