ArrayList深度分析:ArrayList和數組間的相互轉換
一、ArrayList轉換為數組
ArrayList提供public <T> T[] toArray(T[] a)方法返回一個按照正確的順序包含此列表中所有元素的數組,返回數組的運行時類型就是指定數組的運行時類型。
import java.util.ArrayList; import java.util.List; public class Test { public static void main(String[] args) { List<String> list=new ArrayList<String>(); list.add("a"); list.add("b"); list.add("c"); int size=list.size(); String[] array = (String[])list.toArray(new String[size]); for(int i=0;i<array.length;i++){ System.out.println(array[i]); } } }
二、數組轉換為List
2.1 其實數組轉換成為List的問題,Arrays對象也提供給我們public static <T> List<T> asList(T... a)供我們調用。
import java.util.Arrays; import java.util.List; public class Test { public static void main(String[] args) { String[] array=new String[3]; array[0]="a"; array[1]="b"; array[2]="c"; List<String> list=Arrays.asList(array);for(int i=0;i<list.size();i++){ System.out.println(list.get(i)); } } }
這不是最好的,因為asList()返回的列表的大小是固定的。事實上,返回的列表不是java.util.ArrayList,而是定義在java.util.Arrays中一個私有靜態類。我們知道ArrayList的實現本質上是一個數組,而asList()返回的列表是由原始數組支持的固定大小的列表。這種情況下,如果添加或刪除列表中的元素,程序會拋出異常UnsupportedOperationException。
2.2 最好的方式是這樣的:
ArrayList<Element> arrayList = new ArrayList<Element>(Arrays.asList(array));
import java.util.ArrayList; import java.util.Arrays; public class Test { public static void main(String[] args) { String[] array=new String[3]; array[0]="a"; array[1]="b"; array[2]="c"; ArrayList<String> arrayList = new ArrayList<String>(Arrays.asList(array)); for(int i=0;i<arrayList.size();i++){ System.out.println(arrayList.get(i)); } } }
首先,我們來看下ArrayList的構造方法的文檔。
ArrayList(Collection < ? extends E > c) : 構造一個包含特定容器的元素的列表,並且根據容器叠代器的順序返回。
所以構造方法所做的事情如下:
1.將容器c轉換為一個數組
2.將數組拷貝到ArrayList中稱為”elementData”的數組中
ArrayList的構造方法的源碼如下:
public ArrayList(Collection<? extends E> c) { elementData = c.toArray(); size = elementData.length; if (elementData.getClass() != Object[].class) elementData = Arrays.copyOf(elementData, size, Object[].class); }
參考原文:http://www.myasker.com/archives/160.html
ArrayList深度分析:ArrayList和數組間的相互轉換