问题引子:
ist students=newArrayList();
students.add(newStudent("20160800612"));
System.out.println(students.contains(newStudent("20160800612")))
返回FALSE
Student stu=newStudent("123");students.add(stu);System.out.println(students.contains(stu));
返回TRUE
对于以上代码,相信很多人有问题,这种不能靠主管想象力的,,,,我们还是来看后台代码靠谱
按住ctrl键点击contains进入List.class是一个接口,其中有的一个抽象方法 boolean contains(Object o);
他实际上调用的contains方法是ArrayList类中重新的contains方法
publicboolean contains(Object o) {returnindexOf(o) >= 0;
}
按住ctrl键点击indexOf进入ArrayList类中indexOf方法
publicint indexOf(Object o) {if(o ==null) {for(inti = 0; i < size; i++)if(elementData[i]==null)return i;
} else {for(inti = 0; i < size; i++)if (o.equals(elementData[i]))return i;
}return-1;
}
我们看到Object o会调用equals方法,但是Student中并没有重新equals方法,所以最后调用的事Object 中的equals方法
publicboolean equals(Object obj) {return(this== obj);
}
很明显,this==obj比较的事地址,所以两个new的对象地址肯定不是一样的,所以返回false
懂了吧~~~~~~~~~~~~~
所以还是多分析分析后台代码,更加清楚明白啦
怎么解决这个问题呢,就是在Student类中重写这个 equals方法,比较的时候去比较id 但是注意重写时参数是Object 我们需要下转型,这个时候要判断Object是否为Student
@Overridepublicboolean equals(Object obj) {if(objinstanceof Student) return((Student)obj).id.equals(this.id);returnfalse;
}
比较两个List里内容相同的元素内存地址的方法