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

java泛型詳解

 更新時間:2017年03月21日 10:16:36   作者:unbelievableme  
本文主要介紹了java泛型的相關(guān)知識。具有很好的參考價值。下面跟著小編一起來看下吧

首先請看如下代碼:

public class generictype {
 public static void main(String str[]) {
  Hashtable h =new Hashtable();
  h.put(1, "String類型");
  int a = (String) h.get(1);
  System.out.println(a);
 }
}
//執(zhí)行結(jié)果
String類型
//如果我們將上述由紅色標(biāo)出的String改為int執(zhí)行后結(jié)果如下(更改后編譯沒有錯誤):
Exception in thread "main" java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Integer
 at genetictype.generictype.main(generic1.java:10)

以上就是強(qiáng)制類型轉(zhuǎn)換可能帶來的典型錯誤,然而這個錯誤在編譯期間無法知道,以至于在運(yùn)行期間jvm檢查后拋出類型轉(zhuǎn)換異常。

再看下述代碼:

public class generictype { 
 public static void main(String str[]) {  
 Hashtable<Integer, String> h = new Hashtable<Integer, String>();
  h.put(1, "String類型");
  String a= h.get(1);
  System.out.println(a);
 }
}
//執(zhí)行結(jié)果
string類型
//需要提出的是1.上述由紅色標(biāo)出的String如果改為int,在編譯的時候會報(bào)錯
   2.在h.get(1)前面不需要再進(jìn)行強(qiáng)制類型轉(zhuǎn)換。

綜上看來泛型的作用為:

1.就是是在編譯的時候檢查類型的安全(解決java中強(qiáng)制類型轉(zhuǎn)換可能導(dǎo)致的錯誤),交給了編譯器巨大的使命。 

2.提高代碼的重用率

類型擦除:

類型擦除就是說編譯器編譯.java文件時,將類的泛型參數(shù)去掉,那么jvm加載字節(jié)碼文件的時候?qū)Ψ盒筒豢梢?,這個過程就稱為類型擦除。

與類型擦除有關(guān)的現(xiàn)象:

(1) 泛型類沒有Class的類類型。比如并不存在List<String>.class或是List<Integer>.class,而只有List.class。

(2) 靜態(tài)變量是被泛型類的所有實(shí)例所共享的。

public class generictype 
{
 public static void main(String str[]){
  test1<String> t = new test1<String>();
  test1<Date> tt = new test1<Date>();
  System.out.println(t.a);
  System.out.println(tt.a);
 }
}
class test1<T>{
 static int a = 1;
}
//結(jié)果
1

(3) 泛型的類型參數(shù)錯誤不能通過異常處理,因?yàn)楫惓L幚硎莏vm實(shí)現(xiàn)的,而jvm加載的字節(jié)碼文件已經(jīng)擦除了泛型特征,這也間接的說明了泛型的意義:在編譯期間發(fā)現(xiàn)參數(shù)類型錯誤。

類型擦除的基本過程也比較簡單:

 1.將類型參數(shù)用頂級父類替換,這類一般是Object,如果指定了類型參數(shù)的上界的話,則使用這個上界。

 2.去掉出現(xiàn)的類型聲明,即去掉<>的內(nèi)容。

例如:T get()方法聲明就變成了Object get();List<String>就變成了List。接下來就可能需要生成一些橋接方法(bridge method)。這是由于擦除了類型之后的類可能缺少某些必須的方法。比如考慮下面的代碼:

public class generictype {public static void main(String str[]) {
  test3 t =new test3();
   t.getT("11111");
 }
}
interface test2<T>{
 public T getT(T t);
}
class test3 implements test2<String>{
 public String getT(String t){
  return t;
 }
}
//類型擦除后的代碼
public class generictype {
 public static void main(String str[]) {
  test3 t = new test3();
  t.getT("11111");
 }
 interface test2 {
  public Object getT(Object t);
 }
 class test3 implements test2 {
 public String getT(String T){
   return T }
 public Object getT(Object t) {
  return this.getT((String) t);
  }//如果沒有這段代碼,在類型擦除后test3沒有重寫接口test2的抽象方法,明顯錯誤,因此編譯器的巨大作用就是在這里幫忙生成了該方法,同時編譯器也依靠該功能完成檢錯任務(wù)。
}

泛型的分類:泛型類,泛型接口,泛型方法,泛型異常

泛型類

public class generictype {
 public static void main(String str[]) {
  test<Integer, String> t = new test<Integer, String>();
  t.put(1, "str1");
  t.put(2, "str2");
  System.out.println(t.get(1));
  System.out.println(t.get(2));
 }
}
class test<T, V> {
 public Hashtable<T, V> h = new Hashtable<T, V>();
 public void put(T t, V v) {
  h.put(t, v);
 }
 public V get(T t) {
  return h.get(t);
 }
}
//執(zhí)行結(jié)果
str1
str2

多態(tài)方法(泛型方法):在函數(shù)名前定義泛型參數(shù),可以在傳入?yún)?shù)列表,返回值類型,方法體里面引用

public class generictype {
public <T> String getString(T obj){
 return obj.toString();
}
 public static void main(String str[]) {
  generictype g =new generictype ();//不需要類的泛型
  System.out.println(g.getString(1));
  System.out.println(g.getString('a'));
  System.out.println(g.getString("a"));
 }
}
//執(zhí)行結(jié)果
a
a

泛型異常(兼具泛型接口)

public class generictype {
 public static void main(String str[]) {
 TestException t =new TestException();
 try {
  t.excute(2);
 } catch (IOException e) {
  e.printStackTrace();
 }
 }
}
//extends說明該泛型參數(shù)繼承于Exception
interface TestExceptionInterface<T extends Exception>
{
 public void excute(int i) throws T;
}
class TestException implements TestExceptionInterface<IOException>{
 @Override
 public void excute(int i) throws IOException {
 if(i<10){
  throw new IOException();
 }
 }
}
//意義:1.針對不同的可能出現(xiàn)的異常類型,定義自己的實(shí)現(xiàn)類。
  2.定義多個實(shí)現(xiàn)類的時候,不用一個一個手動throws異常,提高了代碼重用率

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!

相關(guān)文章

  • Kotlin?標(biāo)準(zhǔn)函數(shù)和靜態(tài)方法示例詳解

    Kotlin?標(biāo)準(zhǔn)函數(shù)和靜態(tài)方法示例詳解

    這篇文章主要為大家介紹了Kotlin?標(biāo)準(zhǔn)函數(shù)和靜態(tài)方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • 詳解Java8?StreamAPI中的map()方法

    詳解Java8?StreamAPI中的map()方法

    Stream?API?是Java8中新加入的功能,這篇文章主要帶大家了解一下?Stream?API?中的?map()?方法的使用,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-04-04
  • Java后臺接口開發(fā)初步實(shí)戰(zhàn)教程

    Java后臺接口開發(fā)初步實(shí)戰(zhàn)教程

    下面小編就為大家分享一篇 Java后臺接口開發(fā)初步實(shí)戰(zhàn)教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • java調(diào)用百度定位api服務(wù)獲取地理位置示例

    java調(diào)用百度定位api服務(wù)獲取地理位置示例

    java調(diào)用百度定位api服務(wù)獲取地理位置示例,大家參考使用吧
    2013-12-12
  • Spring框架中一個有用的小組件之Spring Retry組件詳解

    Spring框架中一個有用的小組件之Spring Retry組件詳解

    Spring Retry 是從 Spring batch 中獨(dú)立出來的一個功能,主要實(shí)現(xiàn)了重試和熔斷,對于那些重試后不會改變結(jié)果,毫無意義的操作,不建議使用重試,今天通過本文給大家介紹Spring Retry組件詳解,感興趣的朋友一起看看吧
    2021-07-07
  • 解決springboot報(bào)錯Could not resolve placeholder‘xxx‘ in value“${XXXX}

    解決springboot報(bào)錯Could not resolve placeholder‘x

    這篇文章主要介紹了解決springboot報(bào)錯:Could not resolve placeholder ‘xxx‘ in value “${XXXX}問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Java中final修飾的方法是否可以被重寫示例詳解

    Java中final修飾的方法是否可以被重寫示例詳解

    這篇文章主要給大家介紹了關(guān)于Java中final修飾的方法是否可以被重寫的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Java并發(fā)編程加鎖導(dǎo)致的活躍性問題詳解方案

    Java并發(fā)編程加鎖導(dǎo)致的活躍性問題詳解方案

    所謂并發(fā)編程是指在一臺處理器上"同時"處理多個任務(wù)。并發(fā)是在同一實(shí)體上的多個事件。多個事件在同一時間間隔發(fā)生,所以編寫正確的程序很難,而編寫正確的并發(fā)程序則難上加難
    2021-10-10
  • SpringBoot實(shí)現(xiàn)kafka多源配置的示例代碼

    SpringBoot實(shí)現(xiàn)kafka多源配置的示例代碼

    實(shí)際開發(fā)中,不同的topic可能來自不同的集群,所以就需要配置不同的kafka數(shù)據(jù)源,基于springboot自動配置的思想,最終通過配置文件的配置,自動生成生產(chǎn)者及消費(fèi)者的配置,本文介紹了SpringBoot實(shí)現(xiàn)kafka多源配置,需要的朋友可以參考下
    2024-06-06
  • 詳解java中命令行模式的實(shí)現(xiàn)

    詳解java中命令行模式的實(shí)現(xiàn)

    命令模式是一種行為設(shè)計(jì)模式,它允許您將請求封裝為對象,以便您可以將其參數(shù)化、隊(duì)列化、記錄和撤銷,本文主要為大家介紹一下java實(shí)現(xiàn)命令模式的示例代碼,需要的可以參考下
    2023-09-09

最新評論