2020-10-09
Java培訓
今天好程序員Java培訓給大家分享一篇關于Java泛型繼承原理與用法詳解,結合實例形式分析了Java泛型繼承的相關原理與實現技巧,下面我們一起來看一下吧。
一、
當創建了帶泛型聲明的接口、父類之后,可以為該接口創建實現類,或從該父類來派生子類,但值得指出的是,當使用這些接口、父類時不能再包含類型形參。
如果使用泛型類時沒有傳入實際的類型參數,Java編譯器可能發出警告:使用了未經檢查或不安全的操作——這就是泛型檢查的警告。
二、實戰——傳入實際的類型參數
public class A1 extends Apple<String> {
// 正確重寫了父類的方法,返回值
// 與父類Apple<String>的返回值完全相同
public String getInfo() {
return "子類" + super.getInfo();
}
/*
// 下面方法是錯誤的,重寫父類方法時返回值類型不一致
public Object getInfo()
{
return "子類";
}
*/
}
三、實戰——沒傳入實際的類型參數
public class A2 extends Apple {
// 重寫父類的方法
public String getInfo() {
// super.getInfo()方法返回值是Object類型,
// 所以加toString()才返回String類型
return super.getInfo().toString();
}
}
四、并不存在泛型類
1點睛
雖然可以把ArrayList<String>類當成ArrayList的子類,事實上ArrayList<String>類也確實是一種特殊的ArrayList類,這個ArrayList<String>對象只能添加String對象作為集合元素。但實際上,系統并沒有為ArrayList<String>生成新的class文件,而且也不會把ArrayList<String>當成新類來處理。
實際上,泛型對其所有可能的類型參數,都具有同樣的行為,從而可以把相同的類被當成許多不同的類來處理。與此完全一致的是,類的靜態變量和方法也在所有的實例間共享,所以在靜態方法、靜態初始化、或者靜態變量的聲明和初始化中不允許使用類型形參。
系統中并不會真正生成泛型類,所以instanceof運算符后不能使用泛型類。
2實戰
public class R<T>
{
// 下面代碼錯誤,不能在靜態變量聲明中使用類型形參
// static T info;
T age;
public void foo(T msg){}
// 下面代碼錯誤,不能在靜態方法聲明中使用類型形參
// public static void bar(T msg){}
}
以上就是關于Java培訓之泛型繼承原理與用法詳解的全部內容,希望本文所述對大家Java程序設計有所幫助,想要了解更多關于Java方面內容的小伙伴,請關注好程序員Java培訓官網、微信公眾號等平臺。
開班時間:2021-04-12(深圳)
開班盛況開班時間:2021-05-17(北京)
開班盛況開班時間:2021-03-22(杭州)
開班盛況開班時間:2021-04-26(北京)
開班盛況開班時間:2021-05-10(北京)
開班盛況開班時間:2021-02-22(北京)
開班盛況開班時間:2021-07-12(北京)
預約報名開班時間:2020-09-21(上海)
開班盛況開班時間:2021-07-12(北京)
預約報名開班時間:2019-07-22(北京)
開班盛況Copyright 2011-2023 北京千鋒互聯科技有限公司 .All Right 京ICP備12003911號-5 京公網安備 11010802035720號