先开始map的遍历:数组
Map<String, String> map = new HashMap<String, String>();
map.put("1", "2");
map.put("2", "4");
map.put("3", "1");
map.put("4", "3");spa
1、把key值放进set排序:(使用map.keySet();)--这个效率低(重复的获取value值致使)排序
Set<String> keySet = map.keySet();
for(String str:keySet){
System.out.println(str+"--"+map.get(str));
}get
或者使用iterator遍历string
//while(keySet.iterator().hasNext()){//--注:千万不要懒省事,直接放在里面,会无限循环
//String next = keySet.iterator().next();
//System.out.println(next+"--"+map.get(next));
//}it
Iterator<String> iterator = keySet.iterator();
while(iterator.hasNext()){
String next = iterator.next();
System.out.println(next+"--"+map.get(next));
}io
固然,还可使用普通的for循环--这个此处忽略for循环
2、把map放到set里面遍历(使用map.entrySet())--这个效率高(直接把key、value遍历)效率
Set<Entry<String, String>> entrySet = map.entrySet();
for(Entry<String, String> ds:entrySet){
System.out.println(ds.getKey()+"--"+ds.getValue());
}泛型
或者使用iterator遍历
//while(entrySet.iterator().hasNext()){//--注:千万不要懒省事,直接放在里面,会无限循环
//Entry<String, String> next = entrySet.iterator().next();
//System.out.println(next.getKey()+"--"+next.getValue());
//}
Iterator<Entry<String, String>> iterator = entrySet.iterator();
while(iterator.hasNext()){
Entry<String, String> next = iterator.next();
System.out.println(next.getKey()+"--"+next.getValue());
}
3、按照value值集合遍历(缺点是仅仅能够遍历value值---不能遍历key值,有时有这需求)
Collection<String> values = map.values();
for(String s:map.values()){
System.out.println(s
}
map的values--Collection<String> v = map.values(); 转化为数组或者List集合
Collection<String> values = map.values();
转化为List<String>:
List<String> l=new ArrayList<String>(map.values());
for(String s:l){
System.out.print(s);
}
转化为数组
1.直接为Object[]数组
Object[] array = map.values().toArray();
for(Object s:array){
System.out.print(s);
}
2.转化为value泛型的数组(此处为String[])
String[] strings = map.values().toArray(new String[map.size()]);for(String s:strings){ System.out.print(s);}