欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中關(guān)于泛型接口的使用說明

 更新時(shí)間:2023年08月25日 16:58:07   作者:無奈的碼農(nóng)  
這篇文章主要介紹了Java中關(guān)于泛型接口的使用說明,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

什么是泛型接口

泛型接口是在接口類中有一個(gè)未知對象,一個(gè)可變的對象。

從Java 5開始,引入了參數(shù)化類型(Parameterized Type)的概念,改造了所有的Java集合,使之都實(shí)現(xiàn)泛型,允許程序在創(chuàng)建集合時(shí)就可以指定集合元素的類型,比如List就表名這是一個(gè)只能存放String類型的List;

泛型(Generic):就是指參數(shù)化類型,上面的List就是參數(shù)化類型,因此就是泛型,而String就是該List泛型的類型參數(shù);

泛型的好處 

  • 使集合可以記住元素類型,即取出元素的時(shí)候無需進(jìn)行強(qiáng)制類型轉(zhuǎn)化了,可以直接用原類型的引用接收;
  • 一旦指定了性參數(shù)那么集合中元素的類型就確定了,不能添加其他類型的元素,否則會(huì)直接編譯保存,這就可以避免了“不小心放入其他類型元素”的可能;
  • 上述保證了如果在編譯時(shí)沒有發(fā)出警告,則在運(yùn)行時(shí)就一定不會(huì)產(chǎn)生類型轉(zhuǎn)化異常(ClassCastException);
  • 顯然,泛型使編程更加通用,并且代碼也更加簡潔,代碼更加容易維護(hù);

定義泛型類、接口

不僅Java的集合都定義成了泛型,用戶自己也可以定義任意泛型的類、接口,只要在定義它們時(shí)用<>來指定類型參數(shù)即可;

例如:

public interface SqlInterFace<T> { ... }

其中指定了該泛型的類型參數(shù),這個(gè)T是一個(gè)類型參數(shù)名,用戶可以任意命名(就像方法參數(shù)的形參名一樣),只有在定義該泛型的對象時(shí)將T替換成指定的具體類型從而產(chǎn)生一個(gè)實(shí)例化的泛型對象,一個(gè)泛型接口可以被多個(gè)類實(shí)現(xiàn),可以減少接口的開發(fā)。

例如:

SqlInterFace<BondCode> interFace = new BondCodeService();
SqlInterFace<BondDeal> dealSqlInterFace = new BondDealService();
SqlInterFace<BondDealRecord> bondCodeService = new BondDealRecordService();

實(shí)現(xiàn)/繼承泛型接口/泛型類

定義泛型和使用泛型的概念:主要區(qū)別就是定義和使用

  • 那Java的方法做類比,Java的方法在定義的時(shí)候使用的都是形參(虛擬參數(shù)),但是在調(diào)用方法(使用方法)的時(shí)候必須傳入實(shí)參;
  • 同樣泛型也有這個(gè)特點(diǎn),泛型的類型參數(shù)和方法的參數(shù)一樣,也是一種參數(shù),只不過是一種特殊的參數(shù),用來表示未知的類型罷了;
  • 因此,泛型也是在定義的時(shí)候必須使用形參(虛擬參數(shù),用戶自己隨意命名),但是在使用泛型的時(shí)候(比如定義泛型引用、繼承泛型)就必須使用實(shí)參,而泛型的實(shí)參就是具體的類型,像String、Integer等具體的類型(當(dāng)然也可以是自定義類型);
  • 泛型定義的時(shí)候使用形參,例如:public class MyGeneric { … } // T就是一個(gè)自己隨意命名的類型形參
  • 使用泛型的時(shí)候必須傳入實(shí)參:
  • 定義引用(對象)的時(shí)候毫無疑問,肯定需要傳實(shí)參:ArrayList list = …; // 必須用具體的類型,像這里就是String來代替形參,即實(shí)參

實(shí)現(xiàn)/繼承一個(gè)泛型接口/類的時(shí)候

  • 你在實(shí)現(xiàn)/繼承一個(gè)接口/類的時(shí)候?qū)嶋H上是在使用該接口/類,比如:public class Son extends Father { … }中Father這個(gè)類就是正在被使用,毫無疑問,必定是在使用;
  • 因此泛型其實(shí)無法繼承/實(shí)現(xiàn),因?yàn)樵趯?shí)現(xiàn)/繼承的時(shí)候必須為泛型傳入類型實(shí)參,給定實(shí)參后它就是一個(gè)具體的類型了,就不再是泛型了

示例:

public class MyType extends MyGeneric { … } // implements、extends的時(shí)候必須傳入類型實(shí)參,因?yàn)閷?shí)在使用泛型!!

原則上,任何編程語言都不允許泛型模板層層繼承?。?/p>

繼承之后,父類/接口中的所有方法中的類型參數(shù)都將變成具體的類型,你在子類中覆蓋這些方法的時(shí)候一定要用具體的類型,不能繼續(xù)使用泛型的類型形參了

泛型參數(shù)繼承

  • 上面派生出來的類不是泛型,是一個(gè)實(shí)體類型,因?yàn)槠淅^承的泛型是具有類型實(shí)參的,而Java還支持一種特殊的語法,可以讓你從泛型繼續(xù)派生出泛型,而泛型的類型參數(shù)可以繼續(xù)傳承下去;
  • 語法如下:
class Father<T> { ... }class Son<T> extends Father<T> { ... }
  • 即子泛型可以傳承父泛型的泛型參數(shù),那么在子類中泛型參數(shù)T就和父類的完全相同,還是照常使用(和父類一樣正常使用);

注意:

這里extends Father了,因此父類泛型Father就是被使用了,而按照之前講的規(guī)則,使用給一個(gè)泛型是必須要指定類型實(shí)參的!

因此這里的這個(gè)語法是一種特殊語法,Java專門為這種語法開了后門,這種語法只有在類型參數(shù)傳承的時(shí)候才會(huì)用到(即上面這種應(yīng)用);

一旦使用了這種語法,就表示要進(jìn)行類型參數(shù)的傳承了(即父類的T傳遞給子類繼續(xù)使用,因此子類也是一個(gè)跟父類一樣的泛型);

并且一旦使用了這種語法,那么子類定義中的Son和extends Father中的類型參數(shù)必須和定義父類時(shí)的類型參數(shù)名完全一樣!!

以下三種情況全部錯(cuò)誤(全部發(fā)生編譯報(bào)錯(cuò)):

class Father<T> { }
class Son<E> extends Father<T> { }
class Father<T> { }
class Son<T> extends Father<E> { }
class Father<T> { }
class Son<E> extends Father<E> { }

必須全部使用和父類定義相同的類型參數(shù)名(T)!

才行,這是Java語法的特殊規(guī)定;

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論