Java Integer.valueOf()和Integer.parseInt()的區(qū)別說明
前言
大家都知道Integer類中有Integer.valueOf(String s)和Integer.parseInt(String s)兩個靜態(tài)方法,他們都能夠?qū)⒆址D(zhuǎn)換為整型。說到這里你肯定會想同一個功能為什么要提供兩個不同的方法,這不是浪費(fèi)嗎?
區(qū)別
Integer.parseInt(String s)將會返回int常量。
Integer.valueOf(String s)將會返回Integer類型,如果存在緩存將會返回緩存中已有的對象。
使用不當(dāng)將會產(chǎn)生的問題
由于Java的自動拆箱和裝箱機(jī)制導(dǎo)致我們在使用時一般分別不出有什么區(qū)別。但是在某些要求只能使用Integer類型的地方,如果錯誤的使用了Integer.parseInt(s),會造成一些不可預(yù)料的事情。
大家都知道在java中比較兩個整型是否相等用的是==符號,比較兩個對象用的是Objects.equles()。如果你在判斷一個字符串?dāng)?shù)字是否與某個整型相等時,這樣判斷
int n = 某個整型;if( n == Integer.valueOf(s)){//do something}
就會出現(xiàn)一些不可預(yù)料的問題。
將一個整型n賦值給Integer變量,將會調(diào)用
Integer.valueOf(n);然而Integer.valueOf()是有緩存的,會緩存-128 ~ 127范圍的整型數(shù)字。
Integer.valueOf的源碼
public static Integer valueOf(int i) { if (i >= IntegerCache.low && i <= IntegerCache.high) return IntegerCache.cache[i + (-IntegerCache.low)]; return new Integer(i);}
在IntegerCache中cache數(shù)組初始化存入了-128 - 127的值。
cache = new Integer[(high - low) + 1];int j = low;for( int k = 0; k < cache.length ; k ++) cache[k] = new Integer(j ++);
從上面我們可以知道給Interger 賦予的int數(shù)值在-128 - 127的時候,直接從cache中獲取,這些cache引用對Integer對象地址是不變的,但是不在這個范圍內(nèi)的數(shù)字,則new Integer(i) 這個地址是新的地址。
假如n和Integer.valueOf(s)的范圍在-128 ~ 127之間那么上面那串比較的代碼將會正常工作。
假如兩個之中有一個不在-128 ~ 127之間,那么就會調(diào)用new Integer()重新創(chuàng)建一個Integer對象,由于兩個對象引用的堆地址不一樣,將會返回false,上面的代碼就不會根據(jù)預(yù)期進(jìn)行工作。
補(bǔ)充知識:為什么匿名類是沒有名字的,明明有名字的解釋
首先大家看一下下面的代碼,大家應(yīng)該還算熟悉吧,他其實(shí)就是一個匿名類。
Runnable runnable = new Runnable() { @Override public void run() {for (int i = 1; i <= 20; i++) { ad.loopA(i);} } };
Runnable是一個接口,這個接口前面之所以new 了一下,并不能說明接口可以new,因?yàn)榻涌诶锩嬷貙懥私涌谥械某橄蠓椒╮un。此時表明是一個實(shí)現(xiàn)了接口的具體對象,只不過這個對象沒有名字,可是又奇怪了,這個runnable不是他的名字嗎,不是,這個相當(dāng)于是接口的引用,這個引用指向了這個匿名對象。
上面舉得例子是接口,其實(shí)抽象類也是一樣,可以大概總結(jié)為一句話:
一個父類的引用指向了一個子類的對象實(shí)例,這個子類沒有名字。
以上這篇Java Integer.valueOf()和Integer.parseInt()的區(qū)別說明就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
