黑马程序员技术交流社区
标题:
大家看一下 ,为什么第一步一定要先这样判断?
[打印本页]
作者:
张红
时间:
2012-4-26 19:10
标题:
大家看一下 ,为什么第一步一定要先这样判断?
//重写Object的equals方法
public boolean equals(Object obj)//s2--obj
{
//为了提高效率
if(this == obj)
{
return true;
}
//为了程序的健壮性
if(!(obj instanceof Student))//格式:对象 instanceof 具体的类名
{
return false;
}
Student s = (Student)obj;
if(this.age==s.age)
{
return true;
}
else
{
return false;
}
}
作者:
魏涞
时间:
2012-4-26 19:39
//重写Object的equals方法
public boolean equals(Object obj)//s2--obj
{
//为了提高效率
if(this == obj)//这里判断的是两个对象地址是否相等,当相等时表示2个对象指向同一片内存区域,即表示是同一个对象,
//同一个对象里的属性值肯定相等,可以直接返回结果
{
return true;
}
//为了程序的健壮性
if(!(obj instanceof Student))//格式:对象 instanceof 具体的类名
{
return false;
}
Student s = (Student)obj;
if(this.age==s.age)
{
return true;
}
else
{
return false;
}
}
作者:
一生一世
时间:
2012-4-29 21:26
其实第一步可以不写,因为基本上没有人会这样写Object obj = new Studnet():然后再把obj作为参数传给equals方法。第一步只是为了判断当前对象的引用是不是作为参数传给了重写的equals方法,当然为了严谨,写上更好,这只是我的个人观点
作者:
黄或俊
时间:
2012-5-3 18:30
main方法中:
Student s1=new Student();
Student s2=s1;
如果main方法中是这样的底下根本不用判断,直接返回一个true,这就是提高代码的效率
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2