国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

香港云服务器
服務器之家 - 編程語言 - JAVA教程 - 談談Java類型中ParameterizedType,GenericArrayType,TypeVariabl,WildcardType

談談Java類型中ParameterizedType,GenericArrayType,TypeVariabl,WildcardType

2020-01-10 16:15mrr JAVA教程

這篇文章主要介紹Java類型中ParameterizedType,GenericArrayType,TypeVariabl,WildcardType的相關資料,需要的朋友可以參考下

(1). 和反射+泛型有關的接口類型

java.lang.reflect.Type:java語言中所有類型的公共父接口
java.lang.reflect.ParameterizedType
java.lang.reflect.GenericArrayType
java.lang.reflect.WildcardType

1. Type直接子接口

ParameterizedType,GenericArrayType,TypeVariable和WildcardType四種類型的接口

ParameterizedType: 表示一種參數化的類型,比如Collection
GenericArrayType: 表示一種元素類型是參數化類型或者類型變量的數組類型
TypeVariable: 是各種類型變量的公共父接口
WildcardType: 代表一種通配符類型表達式,比如?, ? extends Number, ? super Integer【wildcard是一個單詞:就是“通配符”】

2. Type直接實現子類 :Class類

3. java.lang.reflect.Type接口

Type所有類型指代的有:原始類型 (raw types)【對應Class】,參數化類型 (parameterizedtypes)【對應ParameterizedType】, 數組類型 (array types)【對應GenericArrayType】,類型變量 (type variables)【對應TypeVariable】,基本數據類型(primitivetypes)【仍然對應Class】

4. java.lang.reflect.ParameterizedType接口

ParameterizedType接口類型的含義

表示參數化類型。比如:Map這種參數化類型

獲取參數化類型<>中的實際類型

源碼聲明:Type[] getActualTypeArguments();

【注意】無論<>中有幾層<>嵌套,這個方法僅僅脫去最外層的<>之后剩下的內容就作為這個方法的返回值。

public static  E methodIV( 
ArrayList> al1, 
ArrayList al2, 
ArrayList al3, 
ArrayListextends Number> al4, 
ArrayList al5){}

那么他的每一參數總體上看都是參數化類型的。

{1}. 對于ArrayList>,通過getActualTypeArguments()返回之后,脫去最外層的<>之后,剩余的類型是ArrayList。因此對這個參數的返回類型是ParameterizedType。

{2}. 對于ArrayList,通過getActualTypeArguments()返回之后,脫去最外層的<>之后,剩余的類型是E。因此對這個參數的返回類型是TypeVariable。

{3}. 對于ArrayList,通過getActualTypeArguments()返回之后,脫去最外層的<>之后,剩余的類型是String。因此對這個參數的返回類型是Class。

{4}. 對于ArrayListextends Number>,通過getActualTypeArguments()返回之后,脫去最外層的<>之后,剩余的類型是? ExtendsNumber。因此對這個參數的返回類型是WildcardType。

{5}. 對于ArrayList,通過getActualTypeArguments()返回之后,脫去最外層的<>之后,剩余的類型是E[]。因此對這個參數的返回類型是GenericArrayType。

所以,可能獲得各種各樣類型的實際參數,所以為了統一,采用直接父類數組Type[]進行接收。

4. java.lang.reflect. GenericArrayType接口

GenericArrayType接口類型的含義

表示泛型數組類型。比如:void method(ArrayList[] al){…}

【注意】<>不能出現在數組的初始化中,即new數組之后不能出現<>,否則javac無法通過。但是作為引用變量或者方法的某個參數是完全可以的。

獲取泛型數組中元素的類型

源碼聲明:Type getGenericComponentType();

【注意】無論從左向右有幾個[]并列,這個方法僅僅脫去最右邊的[]之后剩下的內容就作為這個方法的返回值。

為什么返回值類型是Type?

?
1
2
3
4
5
public static E methodV(
String[] p1,
E[] p2,
ArrayList[] p3,
E[][] p4){}

{1}. 對于String[],通過getComponentType()返回之后,脫去最右邊的[]之后,剩余的類型是String。因此對這個參數的返回類型是Class

{2}. 對于E[],通過getComponentType()返回之后,脫去最右邊的[]之后,剩余的類型是E。因此對這個參數的返回類型是TypeVariable

{3}. 對于ArrayList[],通過getComponentType()返回之后,脫去最右邊的[]之后,剩余的類型是ArrayList。因此對這個參數的返回類型是ParameterizedType

{4}. 對于E[][],通過getComponentType()返回之后,脫去最右邊的[]之后,剩余的類型是E[]。因此對這個參數的返回類型是GenericArrayType

5. java.lang.reflect. GenericArrayType接口

TypeVariable接口類型的含義

表示類型參數或者又叫做類型變量。比如:void method(E e){}中的E就是類型變量

獲取類型變量的泛型限定的上邊界的類型

源碼聲明:Type[] getActualTypeArguments();

【注意】這里面僅僅是上邊界。原因就是類型變量在定義的時候只能使用extends進行(多)邊界限定。不能使用super,否則編譯無法通過。同時extends給出的都是類型變量的上邊界。

為什么是返回類型是數組?因為類型變量可以通過&進行多個上邊界限定,因此上邊界有多個,因此返回值類型是數組類型[ ]。

例如下面的方法:

?
1
public static extends Map& Cloneable&Serializable> E methodVI(E e){…}

E的第一個上邊界是Map,是ParameterizedType類型

E的第二個上邊界是Cloneable,是Class類型

因此,為統一,返回值的數組的元素類型就是Type

6. java.lang.reflect.WildcardType接口

WildcardType接口類型的含義

表示通配符類型的表達式。

比如 void printColl(ArrayListal); 中的 ? extends Number

【注意】根據上面API的注釋提示:現階段通配符表達式僅僅接受一個上邊界或者下邊界,這個和定義類型變量時候可以指定多個上邊界是不一樣。但是API說了,為了保持擴展性,這里返回值類型寫成了數組形式。實際上現在返回的數組的大小就是1

獲取通配符表達式對象的泛型限定的上邊界的類型

源碼聲明:Type[] getUpperBounds();

【注意】上面說了,現階段返回的Type[ ]中的數組大小就是1個。寫成Type[ ]是為了語言的升級而進行的擴展。

例如下面的方法:

{1}. public static voidprintColl(ArrayListextends ArrayList> al){}

通配符表達式是:? extendsArrayList,這樣 extends后面是?的上邊界,這個上邊界是ParameterizedType類型。

{2}. public static  voidprintColl(ArrayListextends E> al){}

通配符表達式是:? extends E,這樣 extends后面是?的上邊界,這個上邊界是TypeVariable類型

{3}.public static  voidprintColl(ArrayListextends E[]> al){}

通配符表達式是:? extends E[],這樣 extends后面是?的上邊界,這個上邊界是GenericArrayType類型

{4}.public static  voidprintColl(ArrayListextends Number> al){}

通配符表達式是:? extends Number,這樣 extends后面是?的上邊界,這個上邊界是Class類型

最終統一成Type作為數組的元素類型。

7. Type及其子接口的來歷

一. 泛型出現之前的類型

沒有泛型的時候,只有所謂的原始類型。此時,所有的原始類型都通過字節碼文件類Class類進行抽象。Class類的一個具體對象就代表一個指定的原始類型。

二. 泛型出現之后的類型

泛型出現之后,擴充了數據類型。從只有原始類型擴充了參數化類型、類型變量類型、泛型限定的的參數化類型 (含通配符+通配符限定表達式)、泛型數組類型。

三. 與泛型有關的類型不能和原始類型統一到Class的原因

[1]. 【產生泛型擦除的原因】

本來新產生的類型+原始類型都應該統一成各自的字節碼文件類型對象。但是由于泛型不是最初Java中的成分。如果真的加入了泛型,涉及到JVM指令集的修改,這是非常致命的。

[2]. 【Java中如何引入泛型】

為了使用泛型的優勢又不真正引入泛型,Java采用泛型擦除的機制來引入泛型。Java中的泛型僅僅是給編譯器javac使用的,確保數據的安全性和免去強制類型轉換的麻煩。但是,一旦編譯完成,所有的和泛型有關的類型全部擦除。

[3]. 【Class不能表達與泛型有關的類型】

因此,與泛型有關的參數化類型、類型變量類型、泛型限定的的參數化類型 (含通配符+通配符限定表達式)、泛型數組類型這些類型全部被打回原形,在字節碼文件中全部都是泛型被擦除后的原始類型,并不存在和自身類型一致的字節碼文件。所以和泛型相關的新擴充進來的類型不能被統一到Class類中。

(4). 與泛型有關的類型在Java中的表示

為了通過反射操作這些類型以迎合實際開發的需要,Java就新增了ParameterizedType,GenericArrayType,TypeVariable 和WildcardType幾種類型來代表不能被歸一到Class類中的類型但是又和原始類型齊名的類型。

(5). Type的引入:統一與泛型有關的類型和原始類型Class

【引入Type的原因】

為了程序的擴展性,最終引入了Type接口作為Class,ParameterizedType,GenericArrayType,TypeVariable和WildcardType這幾種類型的總的父接口。這樣實現了Type類型參數接受以上五種子類的實參或者返回值類型就是Type類型的參數。

【Type接口中沒有方法的原因】

從上面看到,Type的出現僅僅起到了通過多態來達到程序擴展性提高的作用,沒有其他的作用。因此Type接口的源碼中沒有任何方法。

延伸 · 閱讀

精彩推薦
229
主站蜘蛛池模板: 中文字幕一区二区三区日韩精品 | 精品视频在线免费观看 | 色婷婷一区二区三区 | 久免费视频 | 成人片网址 | 午夜黄色影院 | 中文在线视频 | 农村人乱弄一区二区电影 | 91久久国产露脸精品国产护士 | 欧美日韩一区精品 | 亚洲一区二区三区精品动漫 | 中文字幕视频在线 | 国产乱xxxxx97国语对白 | av网站在线免费观看 | 亚洲一区二区视频 | 91精品综合久久久久久五月天 | 欧美一区二区在线视频 | 午夜影视免费观看 | 日韩中文字幕视频 | 国产欧美久久久久久 | 亚洲一区二区三区精品动漫 | 日韩毛片一区二区三区 | 国产欧美一区二区精品久久 | 91精品在线看| 干干人人 | 操操日 | 91在线精品一区二区 | 成人h免费观看视频 | 99亚洲伊人久久精品影院红桃 | 欧美一级片毛片免费观看视频 | 国产精品一卡二卡 | 欧美久| 欧美一区二区三区的 | 情一色一乱一欲一区二区 | 91av免费在线观看 | 日韩精品一区二区在线观看 | 免费a视频 | 欧美一区二区三区的 | 欧美成人免费在线视频 | 国产99久久精品一区二区永久免费 | 欧美激情视频一区二区三区在线播放 |