第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

obj不為空為什么強轉(zhuǎn)course后還要判斷是否為空

obj不為空為什么強轉(zhuǎn)course后還要判斷是否為空

正在回答

7 回答

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

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

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

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

慕粉小蝸牛 提問者

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

helloworld2008 回復 慕粉小蝸牛 提問者

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

慕粉小蝸牛 提問者

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

qq_lzY

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

==:這個是關(guān)系運算符,運算結(jié)果為一個boolean型的值,而==其比較的是雙等號兩邊的值是否相等,對于基本數(shù)據(jù)類型的變量就直接比較兩值是否相等即可;對于引用數(shù)據(jù)類型變量,比較的則為兩變量的“值”。這里的用“值”是因為,引用數(shù)據(jù)類型的變量名所存儲的是該對象的地址,而不是對象的內(nèi)容。所以,使用==來比較引用數(shù)據(jù)類型的時候?qū)嵸|(zhì)是比較地址值。

equals():這個會有些不同,對于繼承Object類的子類和一些重寫了該方法的之類會用不一樣的結(jié)果(比如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()方法是使用==實現(xiàn)判斷的,那實質(zhì)就是判斷變量本身的值了。而在String中則重寫了該方法。從重寫的方法中可以看得出,該方法對傳遞進來的變量進行各層比較,最后得到結(jié)果,其過程可以分析一下:(本對象.equals(參數(shù)))

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

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

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

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

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

?

?

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

淺談Java中的equals和==

  在初學Java時,可能會經(jīng)常碰到下面的代碼:

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行的輸出結(jié)果不一樣?==和equals方法之間的區(qū)別是什么?如果在初學Java的時候這個問題不弄清楚,就會導致自己在以后編寫代碼時出現(xiàn)一些低級的錯誤。今天就來一起了解一下==和equals方法的區(qū)別之處。

一.關(guān)系操作符“==”到底比較的是什么?

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

  “關(guān)系操作符生成的是一個boolean結(jié)果,它們計算的是操作數(shù)的值之間的關(guān)系”。

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

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);

??? }

?

}

  輸出結(jié)果為 true false true

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

  在Java中游8種基本數(shù)據(jù)類型:

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

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

  字符型: char(2 byte)

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

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

  也就是說比如:

  int n=3;

  int m=3; 

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

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

  String str1;

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

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

  str1= new String("hello");

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

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

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

二.equals比較的又是什么?

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

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

  下面是Object類中equals方法的實現(xiàn):

  

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

  但是有些朋友又會有疑問了,為什么下面一段代碼的輸出結(jié)果是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方法的具體實現(xiàn),同樣在該路徑下,String.java為String類的實現(xiàn)。

  下面是String類中equals方法的具體實現(xiàn):

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

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

  總結(jié)來說:

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

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

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

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

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

?


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

恩恩是的

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

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

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

慕粉小蝸牛 提問者

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

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

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

我感覺可能出于兩個方面的考慮:第一,強轉(zhuǎn)之后的數(shù)據(jù)安全性方面的考慮;第二,對Course內(nèi)容更加嚴謹方面的考量~

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

慕粉小蝸牛 提問者

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

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

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

舉報

0/150
提交
取消

obj不為空為什么強轉(zhuǎn)course后還要判斷是否為空

我要回答 關(guān)注問題
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號