伊谢尔伦2017-04-18 10:44:06
(T[]) Arrays.copyOf(elementData, size, a.getClass());
配列自体の型が a.getClass() であるため、強制転送は成功します。 コード>。
(T[]) Arrays.copyOf(elementData, size, a.getClass());
强转可以成功是因为数组的类型本身就为a.getClass()
。
public static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType) {
@SuppressWarnings("unchecked")
T[] copy = ((Object)newType == (Object)Object[].class)
? (T[]) new Object[newLength]
: (T[]) Array.newInstance(newType.getComponentType(), newLength);
System.arraycopy(original, 0, copy, 0,
Math.min(original.length, newLength));
return copy;
}
通过Array.newInstance(newType.getComponentType(), newLength)
创建的(目标类型)数组对象。
String[] y = (String[]) x.toArray()
无法强制转换是因为array
的数据类型为Object[]
而不是String[]
リーリー
Array.newInstance(newType.getComponentType(), newLength)
によって作成された (ターゲット タイプの) Array オブジェクト。 🎜
<時間>
🎜String[] y = (String[]) x.toArray()
は、array
のデータ型が Object[]
であるためキャストできません。 String[]
の代わりに。 🎜伊谢尔伦2017-04-18 10:44:06
String
是 Object
的子类,但是 String[]
不是 Object[]
的子类,所以对于实际类型是 String
的 Object
引用是可以强转成 String
的。但是 Object[]
怎么都不能强转成 String[]
,只能采用个个赋值的方式,把里面的引用挨个强转再拷贝过来(当然可以用 Arrays.copyOf()
やってみましょう。
伊谢尔伦2017-04-18 10:44:06
サブクラスの値をサブクラスに変換して戻すことは合法です
Object[] の値を String[] にキャストします。この動作は(Integer)(new Object())
に似ています
阿神2017-04-18 10:44:06
ArrayList のジェネリック型E
は、ジェネリック型が指定されていない場合には必要ありません。例:
この場合、2番目の方法は適用できず、強制的な型変換を実行する方法はありません