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)来定制你的自定义类.接口