public class TestHashMap {
public static void main(String[] args) {
Map<String, String> map = new HashMap<String, String>();
for (int i = 0; i < 5; i++) {
map.put(i + "", "value" + i);
}
//第一种方式:通过遍历Map.keySet()遍历HashMap的key和value
firstMethod(map);
//第二种方式:通过遍历values()遍历Map的value,但是不能遍历key
secondMethod1(map);
secondMethod2(map);
//第三种方式:通过Map.entrySet()使用iterator()遍历HashMap的key和value
thirdMethod1(map);
thirdMethod2(map);
}
private static void firstMethod(Map<String, String> map) {
long startTime = System.currentTimeMillis();
System.out.println("第一种方式:通过遍历Map.keySet()遍历HashMap的key和value");
for (String key : map.keySet()) {
System.out.println("key= "+ key + " and value= " + map.get(key));
}
System.out.println("第一种耗时:"+(System.currentTimeMillis() - startTime));
}
private static void secondMethod1(Map<String, String> map) {
long startTime = System.currentTimeMillis();
startTime = System.currentTimeMillis();
System.out.println("第二种方式:通过遍历values()遍历Map的value,但是不能遍历key");
Collection<String> values = map.values();
for(Iterator<String> it2 = values.iterator();it2.hasNext();){
it2.next();
}
System.out.println("第二种耗时:"+(System.currentTimeMillis() - startTime));
}
private static void secondMethod2(Map<String, String> map) {
long startTime = System.currentTimeMillis();
startTime = System.currentTimeMillis();
System.out.println("第二种方式:通过遍历values()遍历Map的value,但是不能遍历key");
for (String v : map.values()) {
System.out.println("value= " + v);
}
System.out.println("第二种耗时:"+(System.currentTimeMillis() - startTime));
}
private static void thirdMethod1(Map<String, String> map) {
long startTime = System.currentTimeMillis();
startTime = System.currentTimeMillis();
System.out.println("第三种方式:通过Map.entrySet()使用iterator()遍历HashMap的key和value");
Iterator<Map.Entry<String, String>> it3 = map.entrySet().iterator();
while(it3.hasNext()){
Map.Entry<String, String> entry = it3.next();
entry.getKey();
entry.getValue();
System.out.println("key:"+entry.getKey()+" value:"+entry.getValue());
}
System.out.println("第三种耗时:"+(System.currentTimeMillis() - startTime));
}
private static void thirdMethod2(Map<String, String> map) {
long startTime = System.currentTimeMillis();
startTime = System.currentTimeMillis();
System.out.println("第三种方式:通过Map.entrySet()使用iterator()遍历HashMap的key和value");
//map容量大时用此种遍历方式
for (Map.Entry<String, String> entry : map.entrySet()) {
System.out.println("key: " + entry.getKey() + " and value: " + entry.getValue());
}
System.out.println("第三种耗时:"+(System.currentTimeMillis() - startTime));
}
}
Java HashMap遍历的三种方式
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 一、对List的遍历有三种方式 List list = new ArrayList();list.add("tes...
- 二叉树(binary tree)是一颗树,其中每个节点都不能有多于两个的儿子。 1.二叉树节点 作为图的特殊形式,...