这个问题在昨天就发现 但是今天才得以解决。。。
两处细节问题:
1、关于为什么要重写String类中的toString方法 才能使在另一个类中打印时不打印出地址和类名
这要从println这个方法的源代码开始——
return语句后面的内容就可以知道了
所以在testFile这个类中就得对其进行重写 直接return 我所定义的属性name
2、为什么contain 这个方法的判断标准是: 是否是同一个对象,而不是name是否相同
判断对象的实质就是判断其地址是否一致 其实昨天的博客在这里要做出矫正——
for循环里的添加进的对象确实是五个不同地址的 但是在循环外的
System.out.println(heros.contains(new testFile(“hero 4”))); 这里的实例化的对象虽然内容一样 但是地址和循环里的肯定是不相同的。
所以返回值会是false
为验证这个猜想
把System.out.println(heros.contains(new testFile(“hero 4”)));放入循环内发现在遍历hero0到hero 3 为false很正常 当到hero 4 和猜想的一致是true
然而testFile sd=new testFile(“what!”); 之后的System.out.println(heros.contains(sd)); 返回为真 是因为引用未改变地址也没改变
3、依照toString的重写 我看了下contain方法的源代码将其中的equals方法重写了
这是contain的方法中的equals的源代码:
发现比较的是对象将其改写成比较属性name——
package test;
public class testFile{
public String name;
public boolean equals(Object sd) {
testFile tmp = (testFile) sd;
return this.name.equals(tmp.name);
}
}
注意:这里并不是递归 name是String类 自然调用String里的equals方法 两种名字一样但是功能不一样。
改写成功后 比较的是内容名称就不是对象(地址)了