Java泛型方法擦除


如果使用無界型別引數,則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