对不起,如果我问一个愚蠢的问题,很久没有用Java练习...... 我写了一些代码来模拟哈希表。 这是我的代码的一个功能:
protected int find(K key){
int avail=-1;
int i=hashValue(key);
int j=i;
do{
Entry<K, V> element = bucket[i];
if(element==null){
if(avail<0){
avail=i;
}
break;
}
if(key.equals(element.getK())){
return i; // found
}
if(element==this.used){
if(avail<0){
avail=i;
}
}
i=(i+1)%capa;
}while(i!=j);
return -(avail+1); // return a hash address
}
奇怪的是,当我将if语句if(element == null)改回一点(除了结构的最开头的任何地方)时,它会警告我这是一个死代码:
protected int find(K key){
int avail=-1;
int i=hashValue(key);
int j=i;
do{
Entry<K, V> element = bucket[i];
if(key.equals(element.getK())){
return i; // found
}
if(element==this.used){
if(avail<0){
avail=i;
}
}
// dead code then
if(element==null){
if(avail<0){
avail=i;
}
break;
}
//dead code then
i=(i+1)%capa;
}while(i!=j);
return -(avail+1); // return a hash address
}
任何人都知道哪个部分出了问题?
答案 0 :(得分:8)
在您的第二个代码示例中,element
不可能是null
,因为您已在上面的行中引用它:element.getK()
行
if(key.equals(element.getK()))
如果那时是null
,那么你会得到一个你没有抓到的NullPointerException
。这意味着该方法不会继续使用if(element == null)
语句。
如果element
不 null
,则if
语句的正文也不会被执行。