亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

obj不為空為什么強轉course后還要判斷是否為空

obj不為空為什么強轉course后還要判斷是否為空

正在回答

7 回答

呵呵【沒有其他意思,只是想笑一下】

你是想說:if(this.name == null)這個判斷嗎?一個對象是引用類型,他的屬性也是引用類型,你判斷了前者,為什么不判斷后者呢。不要區別對待嘛~【前者不是null,也不能保證后者就不是null對吧】【你可以多些幾個語句來證實下哈。。?!?/p>

ps:你看下name聲明的時候,是String類型的吧。比如說我利用不含參構造函數創建了一個對象obj,那他的屬性name就是默認為null值。一個null,你如何使用他的方法呢?如果一個String類型的不是字符串,就可以澤么寫:name.equals();但是null.equals()就是錯誤的,會出現空指針異常!

0 回復 有任何疑惑可以回復我~
#1

慕粉小蝸牛 提問者

this.name==null,為什么還要判斷course.name==null?這樣返回true----上邊已經說了Obj不為空,轉換成course時,他的name不是也不為空嗎?怎么還要判斷
2016-06-23 回復 有任何疑惑可以回復我~
#2

helloworld2008 回復 慕粉小蝸牛 提問者

this 和 obj 是不一樣的,前者是指當前對象,后者是傳進來的參數引用對象。還有奧。obj不為空,不代表他的屬性值name不為空。
2016-06-23 回復 有任何疑惑可以回復我~
#3

慕粉小蝸牛 提問者

非常感謝!
2016-06-24 回復 有任何疑惑可以回復我~
#4

qq_lzY

那你應該說(*^__^*) 嘻嘻……,O(∩_∩)O哈哈~,呵呵對我們玻璃心來說好傷,(吐血,“嘔”)
2016-08-19 回復 有任何疑惑可以回復我~
查看1條回復

==:這個是關系運算符,運算結果為一個boolean型的值,而==其比較的是雙等號兩邊的值是否相等,對于基本數據類型的變量就直接比較兩值是否相等即可;對于引用數據類型變量,比較的則為兩變量的“值”。這里的用“值”是因為,引用數據類型的變量名所存儲的是該對象的地址,而不是對象的內容。所以,使用==來比較引用數據類型的時候實質是比較地址值。

equals():這個會有些不同,對于繼承Object類的子類和一些重寫了該方法的之類會用不一樣的結果(比如String類),先來看一下這個方法在Object類中的源碼:

* @param?? obj?? the reference object with which to compare.

* @return? {@code true} if this object is the same as the obj

???? *????????? argument; {@code false} otherwise.

???? * @see???? #hashCode()

???? * @see???? java.util.HashMap

???? */

??? public boolean equals(Object obj) {

??????? return (this == obj);

}

再來看看String類中的equals()方法:、

???? * @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;

??? }

到這里就可以看得出來,在Object中的equals()方法是使用==實現判斷的,那實質就是判斷變量本身的值了。而在String中則重寫了該方法。從重寫的方法中可以看得出,該方法對傳遞進來的變量進行各層比較,最后得到結果,其過程可以分析一下:(本對象.equals(參數))

1、???????? 先判斷是否和本對象的地址相同,如果相同則返回true

2、???????? 判斷是否是屬于String類,如果不是那就肯定不相同,返回false

3、???????? 將參數強轉為String類型;獲得本對象的長度(具體如何獲得,可查閱String.Java源文件),然后判斷本對象長度和參數的長度是否相同,如果不同則跳出if并返回false

4、???????? 獲取本類的字符型數組和參數的數組,并對兩個數組的每一個元素進行比較,如果每一個都一樣則返回true,否則就返回false。

看到這里就不難看出,對于equals()方法,對于String的比較,并不是和Object類中的一樣,這里是比較對象的內容。下面貼出其他網友的解釋:

?

?

一下是在網上看到的,感覺解釋起來比較簡單易懂:http://www.cnblogs.com/dolphin0520/p/3592500.html

淺談Java中的equals和==

  在初學Java時,可能會經常碰到下面的代碼:

1 String str1 = new String("hello");

2 String str2 = new String("hello");

3????????

4 System.out.println(str1==str2);

5 System.out.println(str1.equals(str2));

  為什么第4行和第5行的輸出結果不一樣?==和equals方法之間的區別是什么?如果在初學Java的時候這個問題不弄清楚,就會導致自己在以后編寫代碼時出現一些低級的錯誤。今天就來一起了解一下==和equals方法的區別之處。

一.關系操作符“==”到底比較的是什么?

  下面這個句話是摘自《Java編程思想》一書中的原話:

  “關系操作符生成的是一個boolean結果,它們計算的是操作數的值之間的關系”。

  這句話看似簡單,理解起來還是需要細細體會的。說的簡單點,==就是用來比較值是否相等。下面先看幾個例子:

public class Main {

?

??? /**

???? * @param args

???? */

??? public static void main(String[] args) {

??????? // TODO Auto-generated method stub

???????

??????? int n=3;

??????? int m=3;

???????

??????? System.out.println(n==m);

???????

??????? String str = new String("hello");

??????? String str1 = new String("hello");

??????? String str2 = new String("hello");

???????

??????? System.out.println(str1==str2);

???????

??????? str1 = str;

??????? str2 = str;

??????? System.out.println(str1==str2);

??? }

?

}

  輸出結果為 true false true

  n==m結果為true,這個很容易理解,變量n和變量m存儲的值都為3,肯定是相等的。而為什么str1和str2兩次比較的結果不同?要理解這個其實只需要理解基本數據類型變量和非基本數據類型變量的區別。

  在Java中游8種基本數據類型:

  浮點型:float(4 byte), double(8 byte)

  整型:byte(1 byte), short(2 byte), int(4 byte)?, long(8 byte)

  字符型: char(2 byte)

  布爾型: boolean(JVM規范沒有明確規定其所占的空間大小,僅規定其只能夠取字面值"true"和"false")

  對于這8種基本數據類型的變量,變量直接存儲的是“值”,因此在用關系操作符==來進行比較時,比較的就是?“值” 本身。要注意浮點型和整型都是有符號類型的,而char是無符號類型的(char類型取值范圍為0~2^16-1).

  也就是說比如:

  int n=3;

  int m=3; 

  變量n和變量m都是直接存儲的"3"這個數值,所以用==比較的時候結果是true。

  而對于非基本數據類型的變量,在一些書籍中稱作為 引用類型的變量。比如上面的str1就是引用類型的變量,引用類型的變量存儲的并不是 “值”本身,而是于其關聯的對象在內存中的地址。比如下面這行代碼:

  String str1;

  這句話聲明了一個引用類型的變量,此時它并沒有和任何對象關聯。

  而 通過new String("hello")來產生一個對象(也稱作為類String的一個實例),并將這個對象和str1進行綁定:

  str1= new String("hello");

  那么str1指向了一個對象(很多地方也把str1稱作為對象的引用),此時變量str1中存儲的是它指向的對象在內存中的存儲地址,并不是“值”本身,也就是說并不是直接存儲的字符串"hello"。這里面的引用和C/C++中的指針很類似。

  因此在用==對str1和str2進行第一次比較時,得到的結果是false。因此它們分別指向的是不同的對象,也就是說它們實際存儲的內存地址不同。

  而在第二次比較時,都讓str1和str2指向了str指向的對象,那么得到的結果毫無疑問是true。

二.equals比較的又是什么?

  equals方法是基類Object中的方法,因此對于所有的繼承于Object的類都會有該方法。為了更直觀地理解equals方法的作用,直接看Object類中equals方法的實現。

  該類的源碼路徑為:C:\Program Files\Java\jdk1.6.0_14的src.zip 的java.lang路徑下的Object.java(視個人jdk安裝路徑而定)。

  下面是Object類中equals方法的實現:

  

  很顯然,在Object類中,equals方法是用來比較兩個對象的引用是否相等,即是否指向同一個對象。

  但是有些朋友又會有疑問了,為什么下面一段代碼的輸出結果是true?

public class Main {

?

??? /**

???? * @param args

???? */

??? public static void main(String[] args) {

??????? // TODO Auto-generated method stub

???????

??????? String str1 = new String("hello");

??????? String str2 = new String("hello");

???????

??????? System.out.println(str1.equals(str2));

??? }

}

  要知道究竟,可以看一下String類的equals方法的具體實現,同樣在該路徑下,String.java為String類的實現。

  下面是String類中equals方法的具體實現:

  可以看出,String類對equals方法進行了重寫,用來比較指向的字符串對象所存儲的字符串是否相等。

  其他的一些類諸如Double,Date,Integer等,都對equals方法進行了重寫用來比較指向的對象所存儲的內容是否相等。

  總結來說:

  1)對于==,如果作用于基本數據類型的變量,則直接比較其存儲的 “值”是否相等;

    如果作用于引用類型的變量,則比較的是所指向的對象的地址

  2)對于equals方法,注意:equals方法不能作用于基本數據類型的變量

    如果沒有對equals方法進行重寫,則比較的是引用類型的變量所指向的對象的地址;

    諸如String、Date等類對equals方法進行了重寫的話,比較的是所指向的對象的內容。

?


0 回復 有任何疑惑可以回復我~

恩恩是的

0 回復 有任何疑惑可以回復我~

hh自己又看了一遍,發現最后一句有語?。骸救绻粋€String類型的不是字符串】呵呵,手殘了,應該說String類型的對象不是null的情況下,可以澤么寫。。。。

0 回復 有任何疑惑可以回復我~
#1

慕粉小蝸牛 提問者

那個true是最后要刪去的
2016-06-24 回復 有任何疑惑可以回復我~

因為Course類型的name屬性也是String類型的,這些引用數據類型默認為null,可能會出現NullPointerException,即:空指針異常。

0 回復 有任何疑惑可以回復我~

我感覺可能出于兩個方面的考慮:第一,強轉之后的數據安全性方面的考慮;第二,對Course內容更加嚴謹方面的考量~

0 回復 有任何疑惑可以回復我~
#1

慕粉小蝸牛 提問者

是不是可以認為obj里邊有ID,name元素,不為空則是兩個可能就有一個ID元素,再次判斷是obj.name是不是空,我這樣理解對與不對,有什么狹隘嗎
2016-06-21 回復 有任何疑惑可以回復我~

這問題沒問清楚,建議多看一遍

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

obj不為空為什么強轉course后還要判斷是否為空

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號