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));
        }
    }
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值