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总的接口来管理对象。同步