List是一個接口,而ArrayList是一個類。
ArrayList繼承並實現了List。
因此List不能被構造,但能夠向上面那樣爲List建立一個引用,而ArrayList就能夠被構造。
List list; //正確 list=null;
List list=new List(); // 是錯誤的用法html
List list = new ArrayList();這句建立了一個ArrayList的對象後把上溯到了List。此時它是一個List對象了,有些ArrayList有可是List沒有的屬性和方法,它就不能再用了。
而ArrayList list=new ArrayList();建立一對象則保留了ArrayList的全部屬性。
這是一個例子:
import java.util.*;java
public class TestList{
public static void main(String[] args){
List list = new ArrayList();
ArrayList arrayList = new ArrayList();函數
list.trimToSize(); //錯誤,沒有該方法。
arrayList.trimToSize(); //ArrayList裏有該方法。
}
}性能
編譯一下就知道結果了。htm
若是這個樣子:
List a=new ArrayList();
則a擁有List與ArrayList的全部屬性和方法,不會減小
若是List與ArrayList中有相同的屬性(如int i),有相同的方法(如void f()),
則a.i是調用了List中的i
a.f()是調用了ArrayList中的f();
---------------------------------------------------------------
問題的關鍵:
爲何要用 List list = new ArrayList() ,而不用 ArrayList alist = new ArrayList()呢?
問題就在於List有多個實現類,如今你用的是ArrayList,也許哪一天你須要換成其它的實現類,如 LinkedList或者Vector等等,這時你只要改變這一行就好了:
List list = new LinkedList(); 其它使用了list地方的代碼根本不須要改動。
假設你開始用 ArrayList alist = new ArrayList(), 這下你有的改了,特別是若是你使用了 ArrayList特有的方法和屬性。對象
地區用 List arr = new ArrayList();定義;行業用 ArrayListarr = new ArrayList();定義;則說明,行業裏用到了ArrayList的特殊的方法.blog
另外的例子就是,在類的方法中,以下聲明:
private void doMyAction(List list){}
這樣這個方法能處理全部實現了List接口的類,必定程度上實現了泛型函數.繼承
若是開發的時候以爲ArrayList,HashMap的性能不能知足你的須要,能夠經過實現List,Map(或者Collection)來定製你的自定義類.接口