哈希崩溃及避免方法

王朝other·作者佚名  2008-05-31
宽屏版  字体: |||超大  

先看下面的一个例子,假如你能毫不犹豫的全部答对,说明你对HashMap基本理解.

import Java.util.Map;

import java.util.HashMap;

import java.util.Set;

import java.util.HashSet;

class HashFail

{

public static void main(String[] args)

{

Map map=new HashMap();

Key k=new Key(10);

map.put(k,"value"); //插入一个key:10

System.out.println(map.get(k)!=null); //这里显然是true

k.i++;//要害地方,key改变了

System.out.println(map.get(k)!=null); //?

System.out.println(map.get(new Key(10))!=null); //?

System.out.println(map.get(new Key(11))!=null); //?

for(int i=0;i<20;i++) map.put(new Object(),new Object());

//这里加一些无用信息,导致rehash过程

System.out.println(map.get(k)!=null); //?

System.out.println(map.get(new Key(10))!=null); //?

System.out.println(map.get(new Key(11))!=null); //?

k.i--;//这里把Key改回去了

System.out.println(map.get(k)!=null); //?

System.out.println(map.get(new Key(10))!=null); //?

System.out.println(map.get(new Key(11))!=null); //?

}

static class Key

{

int i;

Key(int i){

this.i=i;

}

public boolean equals(Object obj){

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有