前言
大家都知道在Java中,除了8種基本數(shù)據(jù)類型外,其他的都是引用類型。使用引用類型是為了更好地貫徹面向?qū)ο蟮乃枷?,那為什么還要保留8種基本數(shù)據(jù)類型呢?
這其實(shí)更多地是照顧程序員的習(xí)慣。為了既照顧程序員的習(xí)慣,同時(shí)又能全面貫徹面向?qū)ο缶幊痰乃枷耄琂ava中引入了包裝類機(jī)制。
所謂的包裝類就是為8種基本數(shù)據(jù)類型分別定義了相應(yīng)的引用類型,其對(duì)應(yīng)關(guān)系如下:
顯然,除了int及char外,其余的包裝類都是將對(duì)應(yīng)的基本數(shù)據(jù)類型的首字母大寫即可。 那為什么要引入包裝類呢?前面已經(jīng)說過,是為了全面貫徹面向?qū)ο蟮木幊趟枷?,具體地說就是非引用類型的數(shù)據(jù)在使用時(shí)會(huì)有許多制約,比如List list=new ArrayList();
對(duì)于引用類型,可直接使用list.add(obj);
進(jìn)行添加,但是對(duì)于基本數(shù)據(jù)類型則無法添加,從而不能使用ArrayList中的許多方法(如排序、刪除等),顯然會(huì)造成許多不便,而使用包裝類則可以很好地避免這種缺陷。
同時(shí),從JDK 1.5開始提供了自動(dòng)裝箱和自動(dòng)拆箱的功能,因而目前可以有以下3種初始化包裝類的方法:
方法1:直接傳入相應(yīng)的基本數(shù)據(jù)類型變量或常量,如
1
2
3
|
int a1= 3 ;Integer a2= new Integer(a1); Float f= new Float( 3 .14f); Boolean b= new Boolean( true ); |
方法2:通過傳入字符串,如
1
2
3
|
Integer a= new Integer( "3" ); Float f= new Float( "3.14" ); Boolean b= new Boolean( "true" ); |
值得注意的是使用"True"也可以,如Boolean b=new Boolean(“True”);
方法3:通過自動(dòng)裝箱功能,如Integer a=3;Float f=3.14f;Boolean b=true;
值得注意的是可使用new Float(“3.14”)
和new Float(“3.14f”)
這樣的語句來初始化Float類型變量,但是卻不能使用Float f=3.14;
來初始化Float類型變量,因?yàn)?.14是double類型,它只能被自動(dòng)裝箱為Double類型變量。
我們知道,引用類型使用==進(jìn)行比較時(shí),只有當(dāng)二者指向同一個(gè)對(duì)象時(shí),才會(huì)返回true,否則即使值相等也返回false.包裝類也屬于引用類型,所以以下代碼的執(zhí)行結(jié)果為false,
1
2
3
|
Float f1= new Float( 3 .14f); Float f2= new Float( 3 .14f); System.out.println(f1==f2); |
但是,下面一段代碼的輸出結(jié)果卻和前面討論的不一樣,這是為什么呢?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
import java.util.*; public class TestWrapperClass { public static void main(String[]args) { Integer t1= 3 ; Integer t2= 3 ; System.out.println(t1==t2); Integer t3= 128 ; Integer t4= 128 ; System.out.println(t3==t4); Boolean b1= true ; Boolean b2= true ; System.out.println(b1==b2); } } |
其輸出結(jié)果如下圖所示:
如果按照前面的討論,應(yīng)該都輸出false才對(duì),但這里t1與t2,b1與b2的比較結(jié)果卻為true.這不科學(xué)啊!
原來,Java為了獲得更高的執(zhí)行效率,在某些類的設(shè)計(jì)中引入了緩存機(jī)制!
此處的Integer及Boolean類的設(shè)計(jì)即是如此。java.lang.Integer
類的部分源代碼如下所示:
1
2
3
4
5
|
static final Integer[]cache= new Integer[-(- 128 )+ 127 + 1 ]; static { for ( int i= 0 ;i<cache.length;i++) cache[i]= new Integer[i- 128 ); } |
顯然,系統(tǒng)把-128~127之間的整數(shù)裝箱成Integer實(shí)例,并通過cache數(shù)組進(jìn)行緩存,所以只要是-128~127之間的Integer類型變量,其指向的對(duì)象都是cache數(shù)組成員,從而只要有兩個(gè)值相同且在-128~127之間的Integer變量,它們指向的對(duì)象就是同一個(gè),故采用==進(jìn)行比較時(shí)也返回true.Boolean的情形與之類似。
實(shí)際上,不只是在Java中,在Android中的一些類也采用了緩存機(jī)制,如Android中的ListView就是一個(gè)典型的例子,在繼承的方法getView中,convertView其實(shí)就是采用了緩存機(jī)制,從而大大節(jié)省了系統(tǒng)資源開支,加快了圖形渲染的速度。此處暫且不表,在后面還會(huì)再提到。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言留言交流。