Java——容器(List)

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

相关文章
相关标签/搜索