一、HashMap类中hash(Object key)方法分析
由于在remove()方法的底层实现过程中涉及到了hash,所以在分析remove()方法执行过程之前必须了解HashMap类中hash(Object key)方法是如何实现的。下面是截取的HashMap类中hash(Object key)方法的代码:
static final int hash(Object key) {
int h;
return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);
}
由上述代码可知,HashMap类中的hash(Object key)方法返回的hash值主要是由传入对象调用hashCode()方法决定的。请看下面示例代码:
//a、String类型:如果内容相同,则返回值相同
int hash = hash("Tom");
System.out.println(hash);//84275
hash = hash(new String("Tom"));
System.out.println(hash);//84275
//b、基本数据类型包装类:如果值相同,则返回值相同
hash = hash(10000);
System.out.println(hash);//10000
hash = hash(new Integer(10000));
System.out.println(hash);//10000
//c、自定义类型:如果地址不同则返回结果不同
hash = hash(new Person());
System.out.println(hash);//2018677104
Person person = new Person();
hash = hash(person);
System.out.println(hash);//1311071082
hash = hash(person);
System.out.println(hash);//1311071082
运行结果分析:当传入参数对象为String类型时,在调用hash(Object key)方法时,对String类型的对象进行了上转型变成了Object类型,在调用hashCode()方法时产生了多态,表面上虽然是Object类型的参数调用了hashCode()方法,但实际上运行时调用了String类中的hashCode()方法,而Str