关于JAVA中equals和“==”问题
答案:2 悬赏:10 手机版
解决时间 2021-03-26 02:00
- 提问者网友:留有余香
- 2021-03-25 07:26
关于JAVA中equals和“==”问题
最佳答案
- 五星知识达人网友:醉吻情书
- 2021-03-25 09:01
==运算符对于对象来说只会比较对象是否是同一个,而不是比较内容。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。追问麻烦您把我的代码复制到Eclipse里面把鼠标放在equals上面,看看鞋的是不是
boolean java.lang.Object.wquals(Object obj),至少我这里是这样的。那么您说的那个还是调用String的equals()方法就不成立了追答...
你声明个变量Object b = new String("ab");,然后写上b.toString();,鼠标点上去看看是不是也是Object.toString()?这样就使调用Object的toString方法吗?如果是这样的话,那所有多态不就都没用了,辛辛苦苦重写了父类的方法,结果因为变量声明成父类就没用了...
Eclipse显示的是编译时的,真正运行时的方法就是该对象的具体实现类,强转只是改变变量的声明,不会改变内存中的对象的,是什么还是什么。
所以
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显示的是编译时的,真正运行时的方法就是该对象的具体实现类,强转只是改变变量的声明,不会改变内存中的对象的,是什么还是什么。
全部回答
- 1楼网友:持酒劝斜阳
- 2021-03-25 09:35
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方法也是用双等号(==)进行比较的,所以比较后的结果跟双等号(==)的结果相同。追问亲,明显 a和b的内存指向是相同的,都指向常量值“ab”,但是c和d完全不同呀!c和d是两个完全不同的对象,==的情况下都是false,为什么向上转型就变成true了呢?追答String重写了equals方法,你转型到Object,调用的就是Object的equals了。追问这个我当然知道了,就是因为转为Obejct,调用了Object中的equals方法,Object中的equals方法其实就是“==”,就是比较两个内存引用是否相同。但是这两个对象本身内存地址指向是不同的,但是得到的结果却是true,我就是想知道这是为啥!追答这个就要说道String的常量池了,c和d指向的ab这个对象在内存中是相同的地方。追问您错了,c和d的指向是 堆中 new 出来的String对象,而String对象指向 自身的char[] value数组,value数组才指向常量值,这就是 String a ="ab";和Sring a = new String("ab");的区别!常量存在于方法区,也就是和static方法及常量在一个地方, 而new出来的对象虽然也存在于堆中,但却不在方法区中。额。。到底是谁在问谁……追答哈哈,是啊,受教了。
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了。追问这个我当然知道了,就是因为转为Obejct,调用了Object中的equals方法,Object中的equals方法其实就是“==”,就是比较两个内存引用是否相同。但是这两个对象本身内存地址指向是不同的,但是得到的结果却是true,我就是想知道这是为啥!追答这个就要说道String的常量池了,c和d指向的ab这个对象在内存中是相同的地方。追问您错了,c和d的指向是 堆中 new 出来的String对象,而String对象指向 自身的char[] value数组,value数组才指向常量值,这就是 String a ="ab";和Sring a = new String("ab");的区别!常量存在于方法区,也就是和static方法及常量在一个地方, 而new出来的对象虽然也存在于堆中,但却不在方法区中。额。。到底是谁在问谁……追答哈哈,是啊,受教了。
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯