equals()和==的区别?
本人不才,现在我来对前面几个人的回答都做补充,呵呵,因为发现他们有不严谨的地方:
1楼: equals()比较的是对象的值,==比较的是对象的地址。 这句话答得没错! 但 这不是String的区别,所有对象都有这区别
如果你不信,随便生成一个Object obj 它就有方法可以obj.equals(...);
也就是说equals方法是从Object继承来的,Java中任何对象都自动有这个方法;
2楼: equals()方法是可以重写的,是正确的.very good
3楼: 这种说法不对。重写equals方法不一定要重写hashCode方法,重写hashCode()方法的目的是给每个对象提供一个不重复的hash码(类似于id),因为得到这个id值后而这个id值又不会和其它对象重复,所以就可以拿这个id来做比值从而返回equals的值
; 但是我们完全可以不用这个hash码来做比较而可以只凭我们的逻辑来判断。
4楼: 这种说法不对! == 和equals 没有谁比谁优先高级之说,他们是干不同活用的, 你想用谁就用谁,适合不同的情境和地方。
5楼: 这种说法不对!==不是判断对象是否相等,是判断两个对象所引用的内存地址是否是相同的。 另外 .equals()方法绝对不是判断字符串是否相等用的! 这是严重错误, 任何一个Object都有equals方法。不单单是字符串!
这两个概念很简单,但总是能混淆广大程序爱好者,建议大家好好打好基本功。 把概念要弄清楚。
这个问题比较复杂。你需要先了解==,Equals,
ReferenceEquals三者的区别和三者在处理值类型和引用类型上的具体表现。
这里只解释一下你的代码的运行结果:
首先要说明,object作为所有类型的父类,它强制转换其他类型为object类型时并不会将类型实际转换完后单独分配一块内存空间进行存储,它只是一个引用而已。上面代码中obj1=msg3和obj1=“abc”没有区别,obj1和msg3都是对“abc”的引用,被引用的对象始终是那个对象,不会变成别的,obj1所引用的仍然是个string对象。
由于字符串总是常量,所以在分配空间时总是会先扫描字符串常量池中是否有相同的字符串存在,如果存在就不会单独再开辟空间,所以msg3和msg4所引用的“abc”完全是同一个字符串。而string是一种特殊的引用类型,它本身并不和其他引用类型一样处于堆中,它是处于栈中的。
==对于引用类型所表现的行为和ReferenceEquals相同。ReferenceEquals是Object的静态方法,用于比较两个引用类型的对象是否是对于同一个对象的引用。对于值类型它总是返回false(值类型在封装成相应的值类时总是单独开辟空间,如2个相同的int值在栈中就占2块不同的空间,和字符串是不同的)。因此,msg3==msg4为true;而obj1==obj2同样相当于Object.ReferenceEquals(obj1,obj2),obj1和obj2同样是对同一个对象“abc”的引用。结果也为true。如果obj1=1,obj2=1,结果就是false,因为两个1封装为值类型后占用了不同的内存空间,是不同的对象。
==对值类型则是完全判断两个值的代数值是否相等,其他一概不管。比如一个int的10和一个double的10使用==判断就是相等的。尽管他们是不同的值类型的两个对象。
Equals对于值类型二者表现为只要类型相同并且值相等,就为true,否则为false。int的10和double的10使用Equals判断就是不等的。而对于引用类型,表现同样和ReferenceEquals相同,只要引用的是同一个对象,结果就为true,否则False。
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!