List是一個接口,而ListArray是一個類。
ListArray繼承並實現了List。
因此List不能被構造,但能夠向上面那樣爲List建立一個引用,而ListArray就能夠被構造。
List list; //正確 list=null;
List list=new List(); // 是錯誤的用法java
List list = new ArrayList();這句建立了一個ArrayList的對象後把上溯到了List。此時它是一個List對象了,有些ArrayList有可是List沒有的屬性和方法,它就不能再用了。
而ArrayList list=new ArrayList();建立一對象則保留了ArrayList的全部屬性。
這是一個例子:
import java.util.*;函數
public class TestList{
public static void main(String[] args){
List list = new ArrayList();
ArrayList arrayList = new ArrayList();性能
list.trimToSize(); //錯誤,沒有該方法。
arrayList.trimToSize(); //ArrayList裏有該方法。
}
}線程
編譯一下就知道結果了。對象
若是這個樣子:
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()呢?繼承
若是直接聲明爲ArrayList<String> list=new ArrayList<String>()這個也沒有問題。
而聲明成:List<String> list=new ArrayList<String>();這樣的形式使得list這個對象能夠有多種的存在形式,好比要用鏈表存數據的話直接用LinkedList,使用ArrayList或者Vector直接經過list去=就能夠了,這樣讓list這個對象活起來了,
再好比你須要換成其它的實現類,如 LinkedList或者Vector等等,這時你只要改變這一行就好了:
List list = new LinkedList(); 其它使用了list地方的代碼根本不須要改動。
假設你開始用 ArrayList alist = new ArrayList(), 這下你有的改了,特別是若是你使用了 ArrayList特有的方法和屬性。接口
地區用 List arr = new ArrayList();定義;行業用 ArrayListarr = new ArrayList();定義;則說明,行業裏用到了ArrayList的特殊的方法.內存
另外的例子就是,在類的方法中,以下聲明:
private void doMyAction(List list){}
這樣這個方法能處理全部實現了List接口的類,必定程度上實現了泛型函數.開發
若是開發的時候以爲ArrayList,HashMap的性能不能知足你的須要,能夠經過實現List,Map(或者Collection)來定製你的自定義類.不少需求只能用一個list,內存有限,或者線程同步,不能有更多的集合對象,使得List總的接口來管理對象。同步