关于JAVA中equals和“==”问题
这几天研究了一下关于String里面equals()方法。得知:Stringa=“ab”;Stringb=“ab”;Stringc=newString("ab");Str...
这几天研究了一下关于String里面equals()方法。得知:
String a = “ab”;String b = “ab”;String c =new String("ab");String d =new String("ab");
a.equals(b)为true a==b 为true c.equals(d)为ture c==d 为false
最近又看了Object类源码 看到Object类中也有equals方法 return this ==obj,测试了一下
Object a = new Object(); Object b = new Object(); a==b为false,感觉Object中的equals()方法类似于“==”
所以尝试结合一下这几个方面,问题出现了:谁能告诉我下面的结果为啥是这样子,难道和向上转型有关?
可是向上转型不是安全的吗。哎,实在想不出为什么,求各位大神解惑,最好有内存分析,3Q!
((Object)a).equals(((Object)b))=true ((Object)c).equals(((Object)d))=true 展开
String a = “ab”;String b = “ab”;String c =new String("ab");String d =new String("ab");
a.equals(b)为true a==b 为true c.equals(d)为ture c==d 为false
最近又看了Object类源码 看到Object类中也有equals方法 return this ==obj,测试了一下
Object a = new Object(); Object b = new Object(); a==b为false,感觉Object中的equals()方法类似于“==”
所以尝试结合一下这几个方面,问题出现了:谁能告诉我下面的结果为啥是这样子,难道和向上转型有关?
可是向上转型不是安全的吗。哎,实在想不出为什么,求各位大神解惑,最好有内存分析,3Q!
((Object)a).equals(((Object)b))=true ((Object)c).equals(((Object)d))=true 展开
展开全部
==运算符对于对象来说只会比较对象是否是同一个,而不是比较内容。String的equals是从Object继承过来的,但重写过,比较的是内容。
所以
a.equals(b)为true
c.equals(d)为ture
a==b 为true 应该是编译器对a和b的定义进行优化的结果
String a = “ab”;String b = “ab”;这里定义的都是常量,编译器会对常量进行优化,最终可能会优化成
public static final String xxx = "ab";
String a = xxx;
String b = xxx;
这里就变成了变量a和变量b引用的是同一个对象,你可以反编译class文件过来看看。
至于c==d 为false这个通过上面的解释应该就能理解了。
这个跟强转没有关系,强转了之后只是引用的变量声明改变了,实际对象没有变化,调用的equals还是String的equals,所以都是true。
所以
a.equals(b)为true
c.equals(d)为ture
a==b 为true 应该是编译器对a和b的定义进行优化的结果
String a = “ab”;String b = “ab”;这里定义的都是常量,编译器会对常量进行优化,最终可能会优化成
public static final String xxx = "ab";
String a = xxx;
String b = xxx;
这里就变成了变量a和变量b引用的是同一个对象,你可以反编译class文件过来看看。
至于c==d 为false这个通过上面的解释应该就能理解了。
这个跟强转没有关系,强转了之后只是引用的变量声明改变了,实际对象没有变化,调用的equals还是String的equals,所以都是true。
追问
麻烦您把我的代码复制到Eclipse里面把鼠标放在equals上面,看看鞋的是不是
boolean java.lang.Object.wquals(Object obj),至少我这里是这样的。那么您说的那个还是调用String的equals()方法就不成立了
追答
...
你声明个变量Object b = new String("ab");,然后写上b.toString();,鼠标点上去看看是不是也是Object.toString()?这样就使调用Object的toString方法吗?如果是这样的话,那所有多态不就都没用了,辛辛苦苦重写了父类的方法,结果因为变量声明成父类就没用了...
Eclipse显示的是编译时的,真正运行时的方法就是该对象的具体实现类,强转只是改变变量的声明,不会改变内存中的对象的,是什么还是什么。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
java中的数据类型,可分为两类:
1.基本数据类型,也称原始数据类型。byte,short,char,int,long,float,double,boolean
他们之间的比较,应用双等号(==),比较的是他们的值。
2.复合数据类型(类)
当他们用(==)进行比较的时候,比较的是他们在内存中的存放地址,所以,除非是同一个new出来的对象,他们的比较后的结果为true,否则比较后结果为false。 JAVA当中所有的类都是继承于Object这个基类的,在Object中的基类中定义了一个equals的方法,这个方法的初始行为是比较对象的内存地 址,但在一些类库当中这个方法被覆盖掉了,如String,Integer,Date在这些类当中equals有其自身的实现,而不再是比较类在堆内存中的存放地址了。
对于复合数据类型之间进行equals比较,在没有覆写equals方法的情况下,他们之间的比较还是基于他们在内存中的存放位置的地址值的,因为Object的equals方法也是用双等号(==)进行比较的,所以比较后的结果跟双等号(==)的结果相同。
1.基本数据类型,也称原始数据类型。byte,short,char,int,long,float,double,boolean
他们之间的比较,应用双等号(==),比较的是他们的值。
2.复合数据类型(类)
当他们用(==)进行比较的时候,比较的是他们在内存中的存放地址,所以,除非是同一个new出来的对象,他们的比较后的结果为true,否则比较后结果为false。 JAVA当中所有的类都是继承于Object这个基类的,在Object中的基类中定义了一个equals的方法,这个方法的初始行为是比较对象的内存地 址,但在一些类库当中这个方法被覆盖掉了,如String,Integer,Date在这些类当中equals有其自身的实现,而不再是比较类在堆内存中的存放地址了。
对于复合数据类型之间进行equals比较,在没有覆写equals方法的情况下,他们之间的比较还是基于他们在内存中的存放位置的地址值的,因为Object的equals方法也是用双等号(==)进行比较的,所以比较后的结果跟双等号(==)的结果相同。
更多追问追答
追问
亲,明显 a和b的内存指向是相同的,都指向常量值“ab”,但是c和d完全不同呀!c和d是两个完全不同的对象,==的情况下都是false,为什么向上转型就变成true了呢?
追答
String重写了equals方法,你转型到Object,调用的就是Object的equals了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询