[Java]HashMap相关操作整理

一、HashMap两种遍历方式:

方式1:效率高


Map map = new HashMap();
Iterator iter = map.entrySet().iterator(); while (iter.hasNext()) {
   Map.Entry entry = (Map.Entry) iter.next();
    Object key = entry.getKey();
   Object val = entry.getValue();
}


方式二:效率低

Map map = new HashMap();
Iterator iter = map.keySet().iterator(); while (iter.hasNext()) {
  Object key = iter.next();
  Object val = map.get(key);
}

二、HashMap排序方式:

复制代码
Map < String, Integer >  map  =   new  HashMap < String, Integer > ();
map.put(
" d " 2 );
map.put(
" c " 1 );
map.put(
" b " 1 );
map.put(
" a " 3 );

List
< Map.Entry < String, Integer >>  infoIds  =
    
new  ArrayList < Map.Entry < String, Integer >> (map.entrySet());

// 排序前
for  ( int  i  =   0 ; i  <  infoIds.size(); i ++ ) {
    String id 
=  infoIds.get(i).toString();
    System.out.println(id);
}
// d 2
// c 1
// b 1
// a 3

// 排序
Collections.sort(infoIds,  new  Comparator < Map.Entry < String, Integer >> () {   
    
public   int  compare(Map.Entry < String, Integer >  o1, Map.Entry < String, Integer >  o2) {      
        
// return (o2.getValue() - o1.getValue()); 
         return  (o1.getKey()).toString().compareTo(o2.getKey());
    }
}); 

// 排序后
for  ( int  i  =   0 ; i  <  infoIds.size(); i ++ ) {
    String id 
=  infoIds.get(i).toString();
    System.out.println(id);
}
// 根据key排序
// a 3
// b 1
// c 1
// d 2
// 根据value排序
// a 3
// d 2
// b 1
// c 1



你可能感兴趣的:([Java]HashMap相关操作整理)