您的位置:首頁技術文章
文章詳情頁

Java Integer.valueOf()和Integer.parseInt()的區別說明

瀏覽:3日期:2022-08-27 09:23:07

前言

大家都知道Integer類中有Integer.valueOf(String s)和Integer.parseInt(String s)兩個靜態方法,他們都能夠將字符串轉換為整型。說到這里你肯定會想同一個功能為什么要提供兩個不同的方法,這不是浪費嗎?

區別

Integer.parseInt(String s)將會返回int常量。

Integer.valueOf(String s)將會返回Integer類型,如果存在緩存將會返回緩存中已有的對象。

使用不當將會產生的問題

由于Java的自動拆箱和裝箱機制導致我們在使用時一般分別不出有什么區別。但是在某些要求只能使用Integer類型的地方,如果錯誤的使用了Integer.parseInt(s),會造成一些不可預料的事情。

大家都知道在java中比較兩個整型是否相等用的是==符號,比較兩個對象用的是Objects.equles()。如果你在判斷一個字符串數字是否與某個整型相等時,這樣判斷

int n = 某個整型;if( n == Integer.valueOf(s)){//do something}

就會出現一些不可預料的問題。

將一個整型n賦值給Integer變量,將會調用

Integer.valueOf(n);然而Integer.valueOf()是有緩存的,會緩存-128 ~ 127范圍的整型數字。

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數組初始化存入了-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數值在-128 - 127的時候,直接從cache中獲取,這些cache引用對Integer對象地址是不變的,但是不在這個范圍內的數字,則new Integer(i) 這個地址是新的地址。

假如n和Integer.valueOf(s)的范圍在-128 ~ 127之間那么上面那串比較的代碼將會正常工作。

假如兩個之中有一個不在-128 ~ 127之間,那么就會調用new Integer()重新創建一個Integer對象,由于兩個對象引用的堆地址不一樣,將會返回false,上面的代碼就不會根據預期進行工作。

補充知識:為什么匿名類是沒有名字的,明明有名字的解釋

首先大家看一下下面的代碼,大家應該還算熟悉吧,他其實就是一個匿名類。

Runnable runnable = new Runnable() { @Override public void run() {for (int i = 1; i <= 20; i++) { ad.loopA(i);} } };

Runnable是一個接口,這個接口前面之所以new 了一下,并不能說明接口可以new,因為接口里面重寫了接口中的抽象方法run。此時表明是一個實現了接口的具體對象,只不過這個對象沒有名字,可是又奇怪了,這個runnable不是他的名字嗎,不是,這個相當于是接口的引用,這個引用指向了這個匿名對象。

上面舉得例子是接口,其實抽象類也是一樣,可以大概總結為一句話:

一個父類的引用指向了一個子類的對象實例,這個子類沒有名字。

以上這篇Java Integer.valueOf()和Integer.parseInt()的區別說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
国产综合久久一区二区三区