Map和List的遍历
Map<String,String>遍历
第一种:普遍使用,二次取值
Map<String, String> map = new HashMap<String, String>();
map.put("key1", "value1");
map.put("key2", "value2");
map.put("key3", "value3");
//第一种:普遍使用,二次取值
System.out.println("通过Map.keySet遍历key和value:");
for (String key : map.keySet()) {
System.out.println("key= "+ key + " and value= " + map.get(key));
}
第二种 iterator遍历
通过Map.entrySet 使用iterator遍历key 和value
Iterator<Map.Entry<String, String>> it = map.entrySet().iterator();
while (it.hasNext()) {
Map.Entry<String, String> entry = it.next();
System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
}
第三种 数据量多的时候
通过Map的entrySet遍历key 和 value
用法:
由于Map中存放的元素均为键值对,故每一个键值对必然存在一个映射关系。
Map中采用Entry内部类来表示一个映射项,映射项包含Key和Value
Map.Entry里面包含getKey()和getValue()方法
Set<Entry<T,V>> entrySet()
该方法返回值就是这个map中各个键值对映射关系的集合。
for (Map.Entry<String, String> entry : map.entrySet()) {
System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
}
第四种 通过Map.values()遍历所有的value,但不能遍历key
for(String v: map.values()){
System.out.println("value="+v);
}
JDK1.8新特性
通过lambda表达式支持,语法看起来更简洁,并且可以同时拿到key和value,但性能略低于entrySet
map.forEach((key,value)->{
System.out.println(key+":"+value)
});
List
遍历List
首先有这么一串代码
List<String> li = new ArrayList<String>();
li.add("1");
li.add("2");
li.add("3");
li.add("4");
第一种使用for循环
优点:效率最高,遍历快,可以根据自定计数器操作元素
缺点:不适用于所有集合,每次需要再应用程序中手动强转和额外的获得list.size,还有一个缺点就是
遍历过程中不允许删除元素
for(int i=0;i< li.size();i++){
System.out.println(li.get(i));
}
使用迭代器(iterator)
优点:迭代器提供了操作元素的方法,可以在遍历中相应地操作元素
缺点:运行复杂,性能稍差,效率相对其他两种遍历方式较低
Iterator <String> it =li.Iterator();
while(it.hasNext()){
System.out.println(it.next());
}
Foreach
优点:代码简洁,不易出错
缺点:只能做简单的遍历,不能在遍历过程中操作(删除、替换)数据集合
for(String s:li){
System.out.println(s);
}
格式:设定一个String 类型的 s ,对List数组对象的li 进行遍历。最后输出s