==和equals的区别
2017-08-23 22:04
507 查看
我们在学习Java的时候会遇到这样的问题:
结果:
这是为什么呢?
因为==是基本数据类型比较值,而引用类型比较的是地址。当new String()的时候,现在堆中开辟一块空间,然后去常量池中找是否存在该字符串的值,如果没有就先在常量池中创建该字符串,再把这个字符串copy给堆中,显然str1和str2所指向的地址值不相同。
那么,str1.equals(str2)位true是什么原因呢?
原来,String重写了Object的equals方法
根据源码可以知道,equals是比较两字符串的值,如果相同就返回true。
注意:Object的equals方法和”==”是一样的,如果重写了就按重写的来。下面是Object的equals源码:
2.如果是引用类型,比较的是地址,如果两个对象指向的是同一个地址,就返回true。
2.另外,如果重写了equals方法一般也要重写hashCode方法,如果只重写一部分的话,会出现存储错误。这个在底层用hash算法中得到了很好的体现,比如说hashSet是不可重复且无序的,那么java是怎么判断他是不是重复的呢,就是通过equals()和hashCode()来判断这两个对象是不是相同的。
String str1 = new String("java"); String str2 = new String("java"); System.out.println("str1==str2:"+str1==str2); System.out.println("str1.equals(str2):"+str1.equals(str2));
结果:
str1==str2:false; str1.equals(str2):true;
这是为什么呢?
因为==是基本数据类型比较值,而引用类型比较的是地址。当new String()的时候,现在堆中开辟一块空间,然后去常量池中找是否存在该字符串的值,如果没有就先在常量池中创建该字符串,再把这个字符串copy给堆中,显然str1和str2所指向的地址值不相同。
那么,str1.equals(str2)位true是什么原因呢?
原来,String重写了Object的equals方法
public boolean equals(Object anObject) { if (this == anObject) { return true; } if (anObject instanceof String) { String anotherString = (String)anObject; int n = value.length; if (n == anotherString.value.length) { char v1[] = value; char v2[] = anotherString.value; int i = 0; while (n-- != 0) { if (v1[i] != v2[i]) return false; i++; } return true; } } return false; }
根据源码可以知道,equals是比较两字符串的值,如果相同就返回true。
注意:Object的equals方法和”==”是一样的,如果重写了就按重写的来。下面是Object的equals源码:
public boolean equals(Object obj) { return (this == obj); }
总结:
==
1.如果是基本数据变量,且都是数值类型,只要两个数的值相同都返回true。其他的如果两个对象都是boolean类型,且值都为true,那么==也是true。byte a = 123; long b = 123; System.out.println(a==b); //true
2.如果是引用类型,比较的是地址,如果两个对象指向的是同一个地址,就返回true。
equals
1.如果子类没有重写Object方法,那么比较的还是地址,如果像String一样重写了equals方法,那么这里比较的是值。2.另外,如果重写了equals方法一般也要重写hashCode方法,如果只重写一部分的话,会出现存储错误。这个在底层用hash算法中得到了很好的体现,比如说hashSet是不可重复且无序的,那么java是怎么判断他是不是重复的呢,就是通过equals()和hashCode()来判断这两个对象是不是相同的。