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.二叉树节点 作为图的特殊形式,...