我發現自己處于一種情況,似乎我需要能夠將作為其他一些非原始類型數組的 Object 轉換為其具體數組類型,以傳遞給泛型。對于非數組類型,同樣的事情是微不足道的:desiredType.cast(o)產生一個正確類型的對象。有人會這么好心地解釋如何用數組來做到這一點,或者為什么這永遠行不通?我正在嘗試做的演示:import java.lang.reflect.Array;import java.util.Arrays;public class Main{ public static <T> void testT(T o) { System.out.println("testT called with " + o + " (" + o.getClass() + ")"); } public static void test(Object o) { testT(o.getClass().cast(o)); } public static void main(String[] args) throws ClassNotFoundException { test(new Integer(5)); Class<?> type = Class.forName("java.lang.Integer"); Object array = Array.newInstance(type, 2); Class<?> arrayType = array.getClass(); Object[] copy = Arrays.copyOf(arrayType.cast(array), Array.getLength(array)); // NOPE. (casting is optional) System.out.println(copy); }}
2 回答

慕運維8079593
TA貢獻1876條經驗 獲得超5個贊
Object[]
如果你想保持動態,你可以將它轉換為它,它會起作用:
Object[] copy = Arrays.copyOf((Object[])arrayType.cast(array), Array.getLength(array));
在引擎蓋下,它將按原樣復制數組,即副本將成為Integer[]
您給定示例的一個。
如果您想要做的更通用,您還可以在轉換之前檢查給定類型是否實際上是一個數組,例如在您的示例中您可以使用arrayType.isArray()
它。

冉冉說
TA貢獻1877條經驗 獲得超1個贊
我對 kotlin jvm 有疑問(它取代了Objectby Any)。typeOf因此,要將泛型轉換為我從kotlin-reflect使用的數組:
private inline fun <reified T> genericReflectionToTypedArray(): T? {
return java.lang.reflect.Array.newInstance(typeOf<T>().arguments[0].type!!.javaType as Class<*>, 10) as T
}
在這種情況下,您會知道這T是一個數組,因此,要獲取數組的類型,您將使用typeOf并將 java 類型作為您的第一個類型參數的類Array<T>。
該newInstance方法采用您的 Array 的 java 類型,第二個參數是數組的長度。在這種情況下,沒有 UNCHECKED CAST。
添加回答
舉報
0/150
提交
取消