JAVA SE包裝類(lèi)和泛型詳細(xì)介紹及說(shuō)明方法
1. 包裝類(lèi)
在JAVA中,共有8種基本類(lèi)型,分別是byte,short,long,int,double,float,char,boolean.但由于JAVA是一門(mén)純面向?qū)ο蟮恼Z(yǔ)言,而且8種基本并非繼承于Object類(lèi),為了在泛型代碼中可以?持基本類(lèi)型,于是JAVA提供了包裝類(lèi)。
1.1 基本數(shù)據(jù)類(lèi)型和對(duì)應(yīng)的包裝類(lèi)
除了 Integer 和 Character, 其余基本類(lèi)型的包裝類(lèi)都是?字??寫(xiě)。
1.2 裝箱和拆箱
- 裝箱:基本數(shù)據(jù)類(lèi)型轉(zhuǎn)換成包裝類(lèi)
int i = 10; Integer ij = new Integer(i); //裝箱
- 拆箱:包裝類(lèi)轉(zhuǎn)換成基本數(shù)據(jù)類(lèi)型
int i = 10; Integer ij = new Integer(i); int j = ii.intValue(); //拆箱
??注意:現(xiàn)在都使用自動(dòng)拆箱和自動(dòng)裝箱?。?!
1.3 自動(dòng)裝箱和自動(dòng)拆箱
為了減少開(kāi)發(fā)者的負(fù)擔(dān),java 提供了?動(dòng)機(jī)制。
- 自動(dòng)裝箱
int i = 10; Integer j = i;//自動(dòng)裝箱
- 自動(dòng)拆箱
Integer j = 10; int a = j;//自動(dòng)拆箱
?提問(wèn):下述代碼分別輸出什么,為什么?
public class Test { public static void main(String[] args) { Integer a = 127; Integer b = 127; Integer c = 128; Integer d = 128; Integer e = -129; Integer f = -129; System.out.println(a == b);//true System.out.println(c == d);//false System.out.println(e == f);//false } }
??注意:a和b是應(yīng)用類(lèi)型,==比較的是身份,比較值要重寫(xiě)equals方法進(jìn)行比較。
答:[-128,127]這個(gè)范圍數(shù)字比較是會(huì)出現(xiàn)true,其他數(shù)字比較則會(huì)出現(xiàn)false。原因是Integer中常用的數(shù)字被放到了常量池里,常用數(shù)字的范圍是[-128,127].
2. 泛型
我們以前學(xué)過(guò)的數(shù)組,只能存放指定類(lèi)型的元素,但是因?yàn)樗蓄?lèi)的父類(lèi)都是Object類(lèi),所以數(shù)組類(lèi)型是否可以創(chuàng)建成Object呢?
class MyArray { private Object[] array = new Object[10]; public Object getPos(int pos) { return this.array[pos]; } public void setVal(int pos,Object val) { this.array[pos] = val; } } public class Test { public static void main(String[] args) { MyArray myArray = new MyArray(); myArray.setVal(0,10); myArray.setVal(1,"hello");//字符串也可以存放 String ret = myArray.getPos(1);//編譯報(bào)錯(cuò) System.out.println(ret); } } //1號(hào)下標(biāo)本?就是字符串,但是確編譯報(bào)錯(cuò)。必須進(jìn)?強(qiáng)制類(lèi)型轉(zhuǎn)換
雖然在這種情況下,當(dāng)前數(shù)組任何數(shù)據(jù)都可以存放,但是,更多情況下,我們還是希望 它只能夠持有?種數(shù)據(jù)類(lèi)型。?不是同時(shí)持有這么多類(lèi)型。所以,泛型的主要目的:就是指定當(dāng)前的容器,要持有什么類(lèi)型的對(duì)象,讓編譯器去做檢查。 此時(shí),就需要把類(lèi)型,作為參數(shù)傳遞。需要什么類(lèi)型,就傳?什么類(lèi)型。
2.1 泛型的語(yǔ)法
基礎(chǔ)寫(xiě)法:
class 泛型類(lèi)名稱(chēng)<類(lèi)型形參列表> { // 這?可以使?類(lèi)型參數(shù) }
其他寫(xiě)法:
class 泛型類(lèi)名稱(chēng)<類(lèi)型形參列表> extends 繼承類(lèi)/* 這?可以使?類(lèi)型參數(shù) */ { // 這?可以使?類(lèi)型參數(shù) }
上述代碼進(jìn)?改寫(xiě)如下:
class MyArray<T> { public Object[] array = new Object[10]; public T getPos(int pos) { return (T)this.array[pos]; } public void setVal(int pos,T val) { this.array[pos] = val; } } public class TestDemo { public static void main(String[] args) { MyArray<Integer> myArray = new MyArray<>();//1 myArray.setVal(0,10); myArray.setVal(1,12); int ret = myArray.getPos(1);//2 System.out.println(ret); myArray.setVal(2,"小朱小朱");//3 編譯報(bào)錯(cuò)?。?! } }
1. 注釋1處,類(lèi)型后加? 指定當(dāng)前類(lèi)型
2. 注釋2處,不需要進(jìn)行強(qiáng)制類(lèi)型轉(zhuǎn)換
3. 注釋3處,代碼編譯報(bào)錯(cuò),此時(shí)因?yàn)樵谧⑨?處指定類(lèi)當(dāng)前的類(lèi)型,此時(shí)編譯器會(huì)在存放元素的時(shí)候幫助我們進(jìn)行類(lèi)型檢查。
代碼解釋?zhuān)?/p>
- 類(lèi)名后的 < T >代表占位符,表?當(dāng)前類(lèi)是?個(gè)泛型類(lèi)
- 【規(guī)范】類(lèi)型形參?般使??個(gè)?寫(xiě)字?表示,常?的名稱(chēng)有:
• E 表示Element
• K 表示 Key
• V 表示 Value
• N 表示 Number
• T 表示 Type
• S, U, V 等等 - 第?、第三、第四個(gè)類(lèi)型
2.2 泛型類(lèi)的使用
泛型類(lèi)<類(lèi)型實(shí)參> 變量名; // 定義?個(gè)泛型類(lèi)引? new 泛型類(lèi)<類(lèi)型實(shí)參>(構(gòu)造?法實(shí)參); // 實(shí)例化?個(gè)泛型類(lèi)對(duì)象 MyArray<Integer> list = new MyArray<Integer>();
注意:泛型只能接受類(lèi),所有的基本數(shù)據(jù)類(lèi)型必須使用包裝類(lèi)!
2.3 裸類(lèi)型(Raw Type)
裸類(lèi)型是?個(gè)泛型類(lèi)但沒(méi)有帶著類(lèi)型實(shí)參,例如 MyArrayList 就是?個(gè)裸類(lèi)型
MyArray list = new MyArray();
2.4 擦除機(jī)制
在編譯時(shí),Java 編譯器會(huì)將泛型類(lèi)型信息從代碼中移除,這個(gè)過(guò)程就叫做類(lèi)型擦除。擦除后,泛型類(lèi)型會(huì)被替換為其邊界類(lèi)型(通常是 Object)或者指定的類(lèi)型。同時(shí)也會(huì)在必要的地方插?類(lèi)型轉(zhuǎn)換以保持類(lèi)型安全。
擦除前:
class MyArray<T> { public Object[] array = new Object[10]; public T getPos(int pos) { return (T)this.array[pos]; } public void setVal(int pos,T val) { this.array[pos] = val; } }
擦除后:
class MyArray { public Object[] array = new Object[10]; public Object getPos(int pos) { return this.array[pos]; } public void setVal(int pos, Object val) { this.array[pos] = val; } }
2.5 泛型的上界
在定義泛型類(lèi)時(shí),有時(shí)需要對(duì)傳?的類(lèi)型變量做?定的約束,可以通過(guò)類(lèi)型邊界來(lái)約束。
語(yǔ)法:
class 泛型類(lèi)名稱(chēng)<類(lèi)型形參 extends 類(lèi)型邊界> { ... } public class MyArray<E extends Number> { ... } //只接受 Number 的?類(lèi)型作為 E 的類(lèi)型實(shí)參
2.6 泛型方法
語(yǔ)法:
?法限定符 <類(lèi)型形參列表> 返回值類(lèi)型 ?法名稱(chēng)(形參列表){...}
示例:
public class Util { //靜態(tài)的泛型?法 需要在static后?<>聲明泛型類(lèi)型參數(shù) public static <E> void swap(E[] array, int i, int j) { E t = array[i]; array[i] = array[j]; array[j] = t; } }
2.7 通配符
?用于在泛型的使?,即為通配符
請(qǐng)觀察下述代碼:
class Message<T> { private T message ; public T getMessage() { return message; } public void setMessage(T message) { this.message = message; } } public class Test { public static void main(String[] args) { Message<String> message = new Message<>() ; message.setMessage("歡迎來(lái)到小朱的CSDN"); fun(message); } public static void fun(Message<String> temp){ System.out.println(temp.getMessage()); } }
以上程序會(huì)帶來(lái)新的問(wèn)題,如果現(xiàn)在泛型的類(lèi)型設(shè)置的不是String,?是Integer.
public class TestDemo { public static void main(String[] args) { Message<Integer> message = new Message() ; message.setMessage(99); fun(message); // 出現(xiàn)錯(cuò)誤,只能接收String } public static void fun(Message<String> temp){ System.out.println(temp.getMessage()); } }
我們需要的解決方案:可以接收所有的泛型類(lèi)型,但是又不能夠讓用戶隨意修改。這種情況就需要使
?通配符"?"來(lái)處理
public class TestDemo { public static void main(String[] args) { Message<Integer> message = new Message() ; message.setMessage(55); fun(message); } // 此時(shí)使?通配符"?"描述的是它可以接收任意類(lèi)型 public static void fun(Message<?> temp){ System.out.println(temp.getMessage()); } }
在"?"的基礎(chǔ)上又產(chǎn)生了兩個(gè)子通配符:
通配符上界:
<? extends 上界> <? extends Number>//可以傳?的實(shí)參類(lèi)型是Number或者Number的?類(lèi)
通配符下界:
<? super 下界> <? super Integer>//代表 可以傳?的實(shí)參的類(lèi)型是Integer或者Integer的?類(lèi)類(lèi)型
總結(jié)
到此這篇關(guān)于JAVA SE包裝類(lèi)和泛型詳細(xì)介紹及說(shuō)明方法的文章就介紹到這了,更多相關(guān)JAVA SE包裝類(lèi)和泛型內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot封裝響應(yīng)實(shí)體的實(shí)例代碼
這篇文章主要介紹了springboot封裝響應(yīng)實(shí)體,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07SpringBoot整合Mybatis-Plus實(shí)現(xiàn)關(guān)聯(lián)查詢
Mybatis-Plus(簡(jiǎn)稱(chēng)MP)是一個(gè)Mybatis的增強(qiáng)工具,只是在Mybatis的基礎(chǔ)上做了增強(qiáng)卻不做改變,MyBatis-Plus支持所有Mybatis原生的特性,本文給大家介紹了SpringBoot整合Mybatis-Plus實(shí)現(xiàn)關(guān)聯(lián)查詢,需要的朋友可以參考下2024-08-08淺談java socket的正確關(guān)閉姿勢(shì)
這篇文章主要介紹了java socket的正確關(guān)閉姿勢(shì),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06System.identityHashCode和hashCode的區(qū)別及說(shuō)明
String調(diào)用hashCode()和System.identityHashCode()返回值不同是因?yàn)镾tring重寫(xiě)了hashCode()方法,而System.identityHashCode()返回對(duì)象的內(nèi)存地址哈希值;Test調(diào)用兩個(gè)方法返回值相同是因?yàn)門(mén)est沒(méi)有重寫(xiě)hashCode()方法,因此兩者調(diào)用底層的JVM_IHashCode方法返回相同值2024-11-11使用Feign傳遞請(qǐng)求頭信息(Finchley版本)
這篇文章主要介紹了使用Feign傳遞請(qǐng)求頭信息(Finchley版本),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03java利用easyexcel實(shí)現(xiàn)導(dǎo)入與導(dǎo)出功能
這篇文章主要介紹了java利用easyexcel實(shí)現(xiàn)導(dǎo)入與導(dǎo)出功能,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助2022-09-09feign實(shí)現(xiàn)傳遞參數(shù)的三種方式小結(jié)
這篇文章主要介紹了feign實(shí)現(xiàn)傳遞參數(shù)的三種方式小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06