【List接口】java
注:<1>List很相似与数组,可是它能够任意改变大小。 算法
<2>ArrayList底层实现是数组,LinkedList底层实现是链表。 数组
【常见方法】 函数
【程序分析】 性能
注:注意区分add方法和set方法的区别。 spa
【经常使用方法】 code
java.util.Collections提供了一些静态方法实现了基于List容器的一些经常使用算法。 对象
(这里不是Collection接口,注意区分) 继承
【经常使用算法程序分析】 接口
package com.company.section2;
import java.util.Arrays;
import java.util.List;
public class UserHandler<T extends User>{
//定义类的时候就对泛型进行限制
// 判断用户是否有权限执行操做
public boolean permit(T user, List<Job> jobs) {
List<Class<?>> iList = Arrays.asList(user.getClass().getInterfaces());
// 判断是不是管理员
if (iList.indexOf(Admin.class) > -1) {
Admin admin = (Admin) user;
/* 判断管理员是否有此权限 */
} else {
/* 判断普通用户是否有此权限 */
}
return false;
}
}
interface User {
}
class UserImpl implements User, Admin {
}
interface Admin {
}
class Job {
}
备注:
1. class<?>中的?表示一个未知的类,不加上<?>不会报错,但会有警告。
2. List接口
3. List与ArrayList
List是接口, 定义了一些方法 可是方法没有被实现。ArrayList是一个类,继承并实现了List接口里边定义的方法。 同时List也能够被别的类所实现,例如Vector, Vector和ArrayList对List定义的方法的实现就有所区别(能够这样理解:ArrayList与Vector均可以实现List里面定义的方法,可是而这实现方式不同)。
List是一个接口,不能被构造,但能够为其建立一个引用,而ArrayList就能够被构造。以下所示:
List list; //正确,list=null
List list = new List(); //错误
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()呢?
问题就在于List有多个实现类,如今你用的是ArrayList,也许哪一天你须要换成其它的实现类,如 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)来定制你的自定义类.