还在傻傻分不清楚equal和==
目錄:
1.==
2.equal
3.==和equal的區別
1.==
(1)我們都知道數據類型分為基本數據類型和引用數據類型,== 在比較不同的數據類型所比較的東西也不一樣
比較基本數據類型:比較的是表面的值
比較引用數據類型:比較的是兩個引用是否引用的是一個對象
2.equal
(1)比較基本數據類型:注意這里equal不能作為比較基本數據類型的方法
(2)比較引用數據類型:這里分為兩種情況
對String和Date等重寫了equal的類來說比較的是對象的內容
對沒重寫的類來說比較的是是否指向同一個對象
看看String源碼:
* Compares this string to the specified object. The result is {@code* true} if and only if the argument is not {@code null} and is a {@code* String} object that represents the same sequence of characters as this* object.** @param anObject* The object to compare this {@code String} against** @return {@code true} if the given object represents a {@code String}* equivalent to this string, {@code false} otherwise** @see #compareTo(String)* @see #equalsIgnoreCase(String)*/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;}可以看出來equal是object里邊的方法,而他的底層也是依賴 == 所以在沒重寫equal的時候,就和 == 一樣比較是不是同一個對象
(3)我們知道String在創建對象的時候可以用new也可以不用new直接賦值
即:
那么二者有啥不同呢
看下面這一題:
這里有一個常量區:
如果想深究參照博主另一篇博客:
內存分析詳解
我們new出來的對象會重新在堆區開辟一塊空間存放對象,但是我們直接賦值的話就會在常量區尋找有沒有一個字符串和賦值用的字符串相同,相同的話就把已經存在的常量區字符串的引用賦給要被賦值的引用,拿上邊得的最后一個c==d舉例,這里為啥是true呢,那是因為c="abc"首先會在方法區查看有沒有一個字符串等于“abc”發現沒有,那么就在方法區創建一個“abc”的對象,然后把這個對象的引用賦值給c,然后d又等于”abc“一樣的在方法區尋找發現方法區有這么一個”abc“的對象,那么就把這個對象的引用給d所以c和d實際上是指一個對象所以返回true
注意這里方法區也在堆區,但是new出來的對象在雖然在堆區里但是在方法區之外
總結
以上是生活随笔為你收集整理的还在傻傻分不清楚equal和==的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java重载与重写的区别你懂了吗
- 下一篇: 深入String、StringBuild