如果使用無界型別引數,則Java編譯器將使用Object
替換通用型別中的型別引數,如果系結引數用作方法引數,則使用引數的型別。
建立一個名稱為:GenericMethodsErasure.java 檔案,並編寫以下程式碼 -
package com.yiibai.demo3;
public class GenericMethodsErasure {
public static void main(String[] args) {
Box<Integer> integerBox = new Box<Integer>();
Box<String> stringBox = new Box<String>();
integerBox.add(new Integer(1992));
stringBox.add(new String("Hello World"));
printBox(integerBox);
printBox1(stringBox);
}
private static <T extends Box> void printBox(T box) {
System.out.println("Value: " + box.get());
}
private static <T> void printBox1(T box) {
System.out.println("Value: " + ((Box) box).get());
}
}
class Box<T> {
private T t;
public void add(T t) {
this.t = t;
}
public T get() {
return t;
}
}
在本範例中,java編譯器將用Object
類替換T
型別,而在型別擦除之後,編譯器會為以下程式碼生成位元組碼。
package com.yiibai.demo3;
public class GenericMethodsErasure {
public static void main(String[] args) {
Box integerBox = new Box();
Box stringBox = new Box();
integerBox.add(new Integer(1992));
stringBox.add(new String("Hello World"));
printBox(integerBox);
printBox1(stringBox);
}
// Bounded Types Erasure
private static void printBox(Box box) {
System.out.println("Value: " + box.get());
}
// Unbounded Types Erasure
private static void printBox1(Object box) {
System.out.println("Value: " + ((Box) box).get());
}
}
class Box {
private Object t;
public void add(Object t) {
this.t = t;
}
public Object get() {
return t;
}
}
在這兩種情況下,執行輸出結果是相同的 -
Value: 1992
Value: Hello World