A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 敗唫①輩ふ 中级黑马   /  2013-11-8 16:57  /  1191 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

package practice;
import java.util.*;
public class MapDemo {
public static void main(String[] args) {
  Map<String,String> map=new HashMap<String, String>();
  
  sop("put:"+map.put("01","zhangsan"));    //输出 put:null
  sop("put:"+map.put("01","lisi"));               //输出 put:zhangsan
}

public static void sop(Object obj){
  System.out.println(obj);
}
}

第一次为什么输出null,添加了一个元素,为什么是返回的是null?
第二次为什么输出zhangsan,一个键对应一个值,lisi把zhangsan覆盖了,为什么输出zhangsan?
请高手指点

评分

参与人数 1技术分 +1 收起 理由
乔兵 + 1

查看全部评分

2 个回复

倒序浏览
这个跟put方法的返回值有关系,你打印的是put的返回值,我记得毕老师的视屏中有讲过
put返回的是与key关联的旧值,就是说,与01关联的旧值,旧值的意思就是以前的键值01所对应的value值,在你第一次put的时候,01值在map中不存在,也没用对应的value值,所以返回null,你就打印了null
  第二次put的时候,map中已经存在01,并且对应的value是zhangsan,而这个张三即将被lisi覆盖,那么zhangsan就成为了01对应的旧值,所以put返回了zhangsan这个旧值,即是被覆盖的值

评分

参与人数 1技术分 +1 收起 理由
乔兵 + 1

查看全部评分

回复 使用道具 举报
根据JDKAPI中HashMap中的put方法
  public V put(K key, V value) {
        if (key == null)
            return putForNullKey(value);
        int hash = hash(key);
        int i = indexFor(hash, table.length);
        for (Entry<K,V> e = table; e != null; e = e.next) {
            Object k;
            if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
                V oldValue = e.value;
                e.value = value;
                e.recordAccess(this);
                return oldValue;
            }
        }

        modCount++;
        addEntry(hash, key, value, i);
       return null;
    }
当你执行map.put("01","zhangsan")操作时,如果key不为空,就会返回oldValue,而你第一次添加元素,则oldValue=null
当你执行map.put("01","lisi1"))操作时,key也不为空,返回的oldValue,当然是第一次添加的zhangsan了

评分

参与人数 1技术分 +1 收起 理由
乔兵 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马