Java之HashMap集合简介及遍历

HashMap集合是一个比较特殊的集合,它集成了ArrayList和LinkedList的特点。ArrayList的优点是索引快,LinkedList的优点是插入或删除方便,而HashMap则是由他们两个的优点集成而来。

HashMap是由一个数组和链表组成,用数组来保存链表的首地址,从而来达到他们两个的优点。HashMap由键和值组成,其中键是唯一的,也就是键不可重复,值则可以重复,如果键重复了则会覆盖之前的数据。判断键的hashCode值是否相同,再判断两元素的equals方法是否为true,如果是自定义类,则要重写hashCode和equals方法。

public class demo {
    public static void main(String[] args) {
        //function();
        function_2();
    }

    public static void function(){
        /**
         * @author admin
         * 使用多态来引用子类对象
         * map.keySet()这个方法会返回map中的key的set集合
         */
        Map map = new HashMap<String,String>();
        map.put("123", "abc");
        map.put("234", "abc");
        map.put("345", "abc");
        System.out.println(map);
        Iterator mapIt = map.keySet().iterator();
        while(mapIt.hasNext()){
            String key = (String) mapIt.next();
            String value = (String) map.get(key);
            System.out.println(key+"---"+value);
        }
        System.out.println("-----------------------");        
    }
    public static void function_1(){
        /**
         * @author admin
         * 使用map.entrySet()方法获得Key-value的关系
         */
        Map map = new HashMap<String,String>();
        map.put("123", "abc");
        map.put("234", "abc");
        map.put("345", "abc");
        Iterator It = map.entrySet().iterator();
        while(It.hasNext()){
            Map.Entry entry = (Map.Entry) It.next();
            String key = (String) entry.getKey();
            String value = (String) entry.getValue();
            System.out.println(key+"---"+value);
        }
    }
    public static void function_2(){
        Map map = new HashMap<String,String>();
        map.put("123", "abc");
        map.put("234", "abc");
        map.put("345", "abc");
        map.put("123", "111");
        for(Object i : map.keySet()){
            System.out.println((String)i+"..."+ (String)map.get(i));
        }
    }
}


猜你喜欢

转载自blog.csdn.net/pycharm_u/article/details/81287961