Java - Map


遍历Map的方法

1、Entry

for (Map.Entry<String, String> entry : map.entrySet()) {
    System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
}

2、Iterator

Iterator iterator = map.entrySet().iterator();
while (iterator .hasNext()) {
    Map.Entry<String, String> entry = iterator .next();
    System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
}

3、keySet()

for (String key : map.keySet()) {
    System.out.println("key= "+ key + " and value= " + map.get(key));
}


HashMap

put(key, value)

1、处理key为null的情况  
    if (key == null)  
        return putForNullKey(value); 

2、计算key的哈希值

int hash = hash(key); 

3、找到该哈希码对应的存储位置

int i = indexFor(hash, table.length); 

4、遍历该存储位置的单链表,如果已存在key,则覆盖entry,否则添加entry。

    for (Entry<K,V> e = table[i]; e != null; e = e.next) {  

        Object k;  

        // key存在则新entry覆盖旧entry  

        if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {  

            V oldValue = e.value;  

            e.value = value;  

            e.recordAccess(this);  

            return oldValue;  

        }  

    } 

    // key不存在则添加entry 

    modCount++;  

    addEntry(hash, key, value, i);  



HashMap和HashSet

相同点

HashMap的K唯一,HashSet的元素唯一。

区别

HashMap实现了Map接口   HashSet实现了Set接口

HashMap储存键值对,而HashSet仅储对象。







  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值