javamap遍历方式(java 遍历map)
JAVA循环遍历Map的几种方法
第一种用for循环
Java代码
for(Map.EntryString, String entry:map.entrySet()){
System.out.println(entry.getKey()+"---"+entry.getValue());
}
第二种用迭代
Java代码
Set set = map.entrySet();
Iterator i = set.iterator();
while(i.hasNext()){
Map.EntryString, String entry1=(Map.EntryString, String)i.next();
System.out.println(entry1.getKey()+"=="+entry1.getValue());
}
用keySet()迭代
Java代码
Iterator it=map.keySet().iterator();
while(it.hasNext()){
String key;
String value;
key=it.next().toString();
value=map.get(key);
System.out.println(key+"--"+value);
}
用entrySet()迭代
Java代码
Iterator it=map.entrySet().iterator();
System.out.println( map.entrySet().size());
String key;
String value;
while(it.hasNext()){
Map.Entry entry = (Map.Entry)it.next();
key=entry.getKey().toString();
value=entry.getValue().toString();
System.out.println(key+"===="+value);
}
java Map 怎么遍历
关于java中遍历map具体有四种方式,请看下文详解。
1、这是最常见的并且在大多数情况下也是最可取的遍历方式,在键值都需要时使用。
MapInteger, Integer map = new?HashMapInteger, Integer();
for?(Map.EntryInteger, Integer entry : map.entrySet()) {
System.out.println("Key = "?+ entry.getKey() + ", Value = "?+ entry.getValue());
}
2、在for-each循环中遍历keys或values。
如果只需要map中的键或者值,你可以通过keySet或values来实现遍历,而不是用entrySet。
MapInteger, Integer map = new?HashMapInteger, Integer();
for?(Integer key : map.keySet()) {
System.out.println("Key = "?+ key);
}
for?(Integer value : map.values()) {
System.out.println("Value = "?+ value);
}
该方法比entrySet遍历在性能上稍好(快了10%),而且代码更加干净。
3、使用Iterator遍历
使用泛型:
MapInteger, Integer map = new?HashMapInteger, Integer();
IteratorMap.EntryInteger, Integer entries = map.entrySet().iterator();
while?(entries.hasNext()) {
Map.EntryInteger, Integer entry = entries.next();
System.out.println("Key = "?+ entry.getKey() + ", Value = "?+ entry.getValue());
}
不使用泛型:
Map map = new?HashMap();
Iterator entries = map.entrySet().iterator();
while?(entries.hasNext()) {
Map.Entry entry = (Map.Entry) entries.next();
Integer key = (Integer)entry.getKey();
Integer value = (Integer)entry.getValue();
System.out.println("Key = "?+ key + ", Value = "?+ value);
}
4、通过键找值遍历(效率低)
MapInteger, Integer map = new?HashMapInteger, Integer();
for?(Integer key : map.keySet()) {
Integer value = map.get(key);
System.out.println("Key = "?+ key + ", Value = "?+ value);
}
假设Map中的键值对为1=11,2=22,3=33,现用方法1来遍历Map代码和调试结果如下:
扩展资料:
1、HashMap的重要参数
HashMap 的实例有两个参数影响其性能:初始容量 和加载因子。容量是哈希表中桶的数量,初始容量只是哈希表在创建时的容量。
加载因子 是哈希表在其容量自动增加之前可以达到多满的一种尺度。当哈希表中的条目数超出了加载因子与当前容量的乘积时,则要对该哈希表进行 rehash 操作(即重建内部数据结构),从而哈希表将具有大约两倍的桶数。
在Java编程语言中,加载因子默认值为0.75,默认哈希表元为101。
2、HashMap的同步机制
注意,此实现不是同步的。 如果多个线程同时访问一个哈希映射,而其中至少一个线程从结构上修改了该映射,则它必须保持外部同步。
(结构上的修改是指添加或删除一个或多个映射关系的任何操作;以防止对映射进行意外的非同步访问,如下:
Map m = Collections.synchronizedMap(new HashMap(...));
参考资料:百度百科-Hashmap
如何高效的遍历Map?你常用的不一定是最快的
如文章标题所言,遍历Map是开发过程中比较常见的行为,实现的方式也有多种方式,本文带领大家一起看看更加高效的遍历 Map 。
首先一起来看看,有哪些遍历 Map 的方式
这种应该算是比较常见的使用方式,也是比较容易理解的
keySet : 获取 map 中所有的 key ,然后依次遍历每个 key 。
这种是我平时开发中用的最多的方式,简单通俗易懂。
但是其性能如何呢?后续待揭秘。
不知道有多少人用过 Java8 中的 parallel模式,本质是一种并行处理方式。
性能如何?稍后揭晓。
不行就找找外援试试?
测试环境如下:Intel i7-4790 3.60 GHz, 16 GB
测试集为小的Map集合(大约100个元素),各个方法耗时如下:
从结果看出,在数据量比较小时, 利用 Java 8中的foreach 暂时领先。
测试集为元素数据量 1000 的 Map 集合,测试结果如下:
从结果集合看,在中等数据量情况下,外援 Eclipse (CS) collections 中的 MutableMap 表现最为优异,勇得第一。
其次为 Java 8 中的 foreach ,位列第二。
测试集为元素数据量 100000 (十万级别) 的 Map 集合,测试结果如下:
利用 iterator 和 Map.Entry 【方法1】稳居第一,领先 第二名差不多7s。
第二名为 Eclipse (CS) collections 中的 MutableMap 位列第二,在大数据量下表现表现比较出色。
指的注意的是之前在小数据量下表现比较出色的 Java 8 中的 foreach ,排名却比较靠后,但是仍然超过了利用 Java8 的 Stream API 。
其中还有另一个现象:利用并行模式计算的 Java8 中的 Stream API parallel ,在大数据量时表现好于 foreach 和 stream api 。
下表为不同数据量情况下的各个方法性能表现
在平时开发中,数据量都不算太大时,剖除外援而言, Java 8 中的 foreach 【方法3】,表现比较优异。而并行运算的 Stream API parallel 【方法8】表现没有想象中好, Stream API 【方法7】表现中规中矩。
主要罗列了多种遍历 Map 的方式,每个实现方式都有各自的特点,有的人喜欢 foreach 的通俗易懂;有的人喜欢 stream 的干净利落。
如果从性能来看,小数据量情况下:优先推荐使用 Java8 Foreach 【方法3】。
大数据量情况下推荐 使用 iterator 和 Map.Entry 【方法1】。
我是大黄,一个只会写 HelloWorld 的程序员,下期见。
Java中便历Map的几种方法
常见的Map遍历有下面四种方法:
import?java.util.HashMap;
import?java.util.Iterator;
import?java.util.Map.Entry;
public?class?MapDemo?{
public?static?void?main(String[]?args)?{
//?准备好需要遍历的Map
HashMapString,?Integer?map?=?new?HashMapString,?Integer();
map.put("Tom",?85);
map.put("Jack",?97);
test1(map);
test2(map);
test3(map);
test4(map);
}
//?方法一:?迭代器方式
//?特点:?效率高,速度快,但是代码量多
public?static?void?test1(HashMapString,?Integer?map)?{
IteratorEntryString,?Integer?it?=?map.entrySet().iterator();
while?(it.hasNext())?{
EntryString,?Integer?e?=?it.next();
System.out.println("name:"?+?e.getKey()?+?"\tscore:"?+?e.getValue());
}
}
//?方法二:?map.entrySet()?for循环
//?特点:?效率也较高,速度较快,且写法比方法一简单?
public?static?void?test2(HashMapString,?Integer?map)?{
for?(EntryString,?Integer?e?:?map.entrySet())?{
System.out.println("name:"?+?e.getKey()?+?"\tscore:"?+?e.getValue());
}
}
//?方法3?map.keySet?for循环
// 特点:效率较慢
public?static?void?test3(HashMapString,?Integer?map)?{
for?(String?key?:?map.keySet())?{
System.out.println("name:"?+?key?+?"\tscore:"?+?map.get(key));
}
}
//?方法四:?forEach?
//?特点?速度较慢,但是代码少,简洁;?(需要Java8或以上版本的支持)
public?static?void?test4(HashMapString,?Integer?map)?{
map.forEach((k,?v)?-?System.out.println("name:"?+?k?+?"\tscore:"?+?v));
}
}
四种方法之间的效率比较
(test1≈test2)(test3≈test4)
推荐: 数据量特别大的时候 使用方法1?: 代码长,但是效率高
数据量较少的, 那么使用方法4: 代码简洁而优雅~
Java中怎么遍历map中value值
Java中遍历Map对象的4种方法:
1、通过Map.entrySet遍历key和value,在for-each循环中使用entries来遍历.推荐,尤其是容量大时。
2、通过Map.keySet遍历key,通过键找值value遍历(效率低),普遍使用,二次取值。
3、如果只需要map中的键或者值,你可以通过Map.keySet或Map.values来实现遍历,而不是用entrySet。在for-each循环中遍历keys或values。
4、通过Map.entrySet使用iterator遍历key和value。
扩展资料:
关于JAVA的遍历知识补充:
1、list和set集合都实现了Iterable接口,所以他们的实现类可以使用迭代器遍历,map集合未实现该接口,若要使用迭代器循环遍历,需要借助set集合。
2、使用EntrySet 遍历,效率更高。
参考资料:
百度百科--Map(映射)
java中map的常用遍历方法有哪些?
ava中map的常用遍历的具体方法有:
一 、在for-each循环中使用entries来遍历。这是最常见的并且在大多数情况下也是最可取的遍历方式。在键值都需要时使用。
二、 在for-each循环中遍历keys或values。如果只需要map中的键或者值,你可以通过keySet或values来实现遍历,而不是用entrySet。
三、使用Iterator遍历。
四、通过键找值遍历(效率低)。
总结:如果仅需要键(keys)或值(values)使用方法二。如果你使用的语言版本低于java 5,或是打算在遍历时删除entries,必须使用方法三。否则使用方法一(键值都要)。