確定泛型類型的類別
在泛型程式領域內,決定泛型類型的類別是必要的被利用。然而,由於泛型的本質,類型資訊通常會在運行時被刪除,這給以後檢索它帶來了挑戰。
範例:
考慮以下泛型class:
public class MyGenericClass<T> { public void doSomething() { // ... T bean = (T)someObject.create(T.class); // ... } }
在上面的範例中,我們嘗試透過傳遞類別文字來建立類別T 的實例。但是,這將導致「類型參數 T 的類別文字非法」錯誤,因為禁止嘗試使用泛型類型作為類別文字。
解決方法:
為了克服這個挑戰,一個可行的解決方法是將泛型類型的類別作為參數傳遞給靜態方法。然後,此方法將使用反射 API 來實例化泛型類型。
public class MyGenericClass<T> { private final Class<T> clazz; public static <U> MyGenericClass<U> createMyGeneric(Class<U> clazz) { return new MyGenericClass<>(clazz); } protected MyGenericClass(Class<T> clazz) { this.clazz = clazz; } public void doSomething() { T instance = clazz.newInstance(); } }
透過遵循此方法,我們規避了使用泛型類型作為類文字的限制,確保必要的類型資訊在運行時可用。雖然它可能是一個不優雅的解決方案,但它提供了一種在具有挑戰性的上下文中確定泛型類型的類別的方法,如原始範例中所示。
以上是如何在運行時確定泛型類型的類別?的詳細內容。更多資訊請關注PHP中文網其他相關文章!