牛骨文教育服务平台(让学习变的简单)
博文笔记

HashMap的四种访问方式

创建时间:2017-08-12 投稿人: 浏览次数:991

第一种:通过Map.entrySet使用iterator遍历key和value

public void visit_1(HashMap<String,Integer> hm){
        Iterator<Map.Entry<String,Integer>> it = hm.entrySet().iterator();
        while(it.hasNext()){
            Map.Entry<String ,Integer> entry = it.next();
            String  key = entry.getKey();
            Integer value = entry.getValue();
        }
    }

第二种:通过Key来遍历value

public void visit_2(HashMap<String,Integer> hm){
        for (String key:hm.keySet()){
            Integer value = hm.get(key);
        }
    }

第三种:通过Map.Entry遍历key和value

 public void visit_3(HashMap<String,Integer> hm){
        for(Map.Entry<String,Integer> entry:hm.entrySet()){
            String key = entry.getKey();
            Integer value = entry.getValue();
        }
    }

第四种:通过Map.keySet使用iterator遍历key和value

public void visit_4(HashMap<Integer,String> hm){
        long startTime = System.currentTimeMillis();
        Iterator<Integer> it = hm.keySet().iterator();
        while(it.hasNext()){
            Integer key = it.next();
            String value = hm.get(key);
        }
        System.out.println("visit_4 10000000 entry:"
                + (System.currentTimeMillis()-startTime) + " milli seconds");
    }

四种方法比较:

package chapter08.c86.c862;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

/**
 * Created by ceoicac on 2017/8/12 10:22.
 */
public class HashMapVisitTest {
    public void visit_1(HashMap<Integer,String> hm){
        long startTime = System.currentTimeMillis();
        Iterator<Map.Entry<Integer,String>> it = hm.entrySet().iterator();
        while(it.hasNext()){
            Map.Entry<Integer,String> entry = it.next();
            Integer  key = entry.getKey();
            String value = entry.getValue();
        }
        System.out.println("visit_1 10000000 entry:"
                + (System.currentTimeMillis()-startTime) + " milli seconds");
    }
    public void visit_2(HashMap<Integer,String> hm){
        long startTime = System.currentTimeMillis();
        for (Integer key:hm.keySet()){
            String value = hm.get(key);
        }
        System.out.println("visit_1 10000000 entry:"
                + (System.currentTimeMillis()-startTime) + " milli seconds");
    }
    public void visit_3(HashMap<Integer,String> hm){
        long startTime = System.currentTimeMillis();
        for(Map.Entry<Integer,String> entry : hm.entrySet()){
            Integer key = entry.getKey();
            String value = entry.getValue();
        }
        System.out.println("visit_1 10000000 entry:"
                + (System.currentTimeMillis()-startTime) + " milli seconds");
    }
    public void visit_4(HashMap<Integer,String> hm){
        long startTime = System.currentTimeMillis();
        Iterator<Integer> it = hm.keySet().iterator();
        while(it.hasNext()){
            Integer key = it.next();
            String value = hm.get(key);
        }
        System.out.println("visit_1 10000000 entry:"
                + (System.currentTimeMillis()-startTime) + " milli seconds");
    }
    public static void main(String [] args){
        HashMap<Integer,String> hm = new HashMap<>();
        for(int i = 1;i <= 10000000;++i){
            hm.put(i,"num: " + i);
        }
        new HashMapVisitTest().visit_1(hm);
        new HashMapVisitTest().visit_2(hm);
        new HashMapVisitTest().visit_3(hm);
        new HashMapVisitTest().visit_4(hm);

    }
}

结果:
这里写图片描述

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。