黑马程序员技术交流社区

标题: 大家看一下 ,为什么第一步一定要先这样判断? [打印本页]

作者: 张红    时间: 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