在運行時result = jedis.rpush(key, (String[])value.toArray()); 報了[Ljava.lang.Object; cannot be cast to [Ljava.lang.String;這個錯后來發現是強轉的問題,java中的強制類型轉換只是針對單個對象的,想要偷懶將整個數組轉換成另外一種類型的數組是不行的,,這和數組初始化時需要一個個來也是類似的。
與 public Object[] toArray() 的比較
public Object[] toArray() {
Object[] result = new Object[size];
System.arraycopy(elementData, 0, result, 0, size);
return result;
}
從源碼中可以看出它僅能返回 Object[]類型的,相當於toArray(new Object[0]) 注意:數組不能強制轉換
不帶參數的toArray方法,是構造的一個Object數組,然后進行數據拷貝,此時進行轉型就會產生ClassCastException
String[] tt =(String[]) list.toArray(new String[0]);
這段代碼是沒問題的,但我們看到String[] tt =(String[]) list.toArray(new String[0]) 中的參數很奇怪,然而去掉這個參數new String[0]卻在運行時報錯。。。該容器中的元素已經用泛型限制了,那里面的元素就應該被當作泛型類型的來看了,然而在目前的java中卻不是的,當直接String[] tt =(String[]) list.toArray()時,運行報錯。
處理方式如下面代碼:
String [] st = (String []) list.toArray(newString[list.size()]);
以下是其他博友給的解決方案 記錄下
解決方案. Solutions
因此在使用toArray的時候可以參考以下三種方式
1. Long[] l = new Long[<total size>];
list.toArray(l);
2. Long[] l = (Long[]) list.toArray(new Long[0]);
3. Long[] a = new Long[<total size>];
Long[] l = (Long[]) list.toArray(a);
1).參數指定空數組,節省空間
String[] y = x.toArray(new String[0]);
2).指定大數組參數浪費時間,采用反射機制
String[] y = x.toArray(new String[100]); //假設數組size大於100
3).姑且認為最好的
String[] y = x.toArray(new String[x.size()]);
以下代碼會出現ClassCastException
List list = new ArrayList();
list.add(new Long(1));
list.add(new Long(2));
list.add(new Long(3));
list.add(new Long(4));
Long[] l = (Long[])list.toArray();//這個語句會出現ClassCastException