位置:首页 > Java技术 > Java基础教程 > Java ArrayList类

Java ArrayList类

ArrayList 类扩展AbstractList,并实现了List接口。支持 ArrayList 动态数组根据需要可以增长。

标准的Java数组是一个固定长度的。创建数组后,他们不能生长或缩小,这意味着必须事先知道数组将容纳多少元素。

数组列表是用初始大小创建。当超出该大小时,该集合会自动放大。当被删除的对象,数组可以被缩小。

ArrayList类支持三种构造函数。第一个构造函数建立一个空的数组列表。

ArrayList( )

下面的构造函数建立一个与集合c 的元素初始化一个数组列表。

ArrayList(Collection c)

下面的构造函数建立一个数组列表,具有指定的初始容量。容量是用于存储元素的底层数组的大小。

元素添加到数组列表的容量会自动增加。

ArrayList(int capacity)

除了从它的父类继承的方法,ArrayList中定义了以下方法:

SN 方法及描述
1 void add(int index, Object element)
插入指定位置的索引在此列表中的指定元素。如果指定的索引超出 range (index < 0 || index > size()),抛出IndexOutOfBoundsException异常。
2 boolean add(Object o) 
将指定的元素添加到此列表的末尾。
3 boolean addAll(Collection c)
所有追加指定collection中的元素添加到此列表的结尾,因为它们是由指定collection的迭代器返回的顺序。抛出NullPointerException异常,如果指定集合为null。
4 boolean addAll(int index, Collection c) 
插入所有指定集合中的元素插入此列表,开始在指定的位置。抛出NullPointerException异常,如果指定集合为null。
5 void clear() 
移除此列表中的元素。
6 Object clone() 
返回此ArrayList浅表副本。
7 boolean contains(Object o) 
如果此列表包含指定的元素返回true。更正式地说,当且仅当此列表包含至少一个元素e,使得返回true (o==null ? e==null : o.equals(e)).
8 void ensureCapacity(int minCapacity) 
增加此ArrayList实例的容量,如果需要,以确保其能容纳至少由最小容量参数指定的元素数。
9 Object get(int index) 
返回此列表中指定位置的元素。抛出IndexOutOfBoundsException异常,如果指定的索引超出range (index < 0 || index >= size()).
10 int indexOf(Object o) 
返回索引中的指定元素第一次出现的这个名单,或者-1,如果列表中不包含该元素。
11 int lastIndexOf(Object o)
返回索引中的指定元素中最后出现的这个名单,或者-1,如果列表中不包含该元素。
12 Object remove(int index) 
移除元素在此列表中的指定位置。如果索引超出 range (index < 0 || index >= size()) 抛出一个IndexOutOfBoundsException。
13 protected void removeRange(int fromIndex, int toIndex) 
从这个列表中删除所有索引为fromIndex(包括)和toIndex,独占的元素。
14 Object set(int index, Object element) 
替换元素在与指定元素在此列表中的指定位置。抛出IndexOutOfBoundsException异常,如果指定的索引超出 range (index < 0 || index >= size()).
15 int size() 
返回此列表中的元素数。
16 Object[] toArray() 
返回包含所有在此列表中正确的顺序元素的数组。抛出NullPointerException异常如果指定数组为null。
17 Object[] toArray(Object[] a) 
返回包含所有在此列表中正确的顺序元素的数组;返回数组的运行时类型是指定数组。
18 void trimToSize() 
这个微调,ArrayList实例的是列表的当前大小容量。

例子:

下面的程序说明了几个ArrayList中所支持的方法:

import java.util.*;

public class ArrayListDemo {
   public static void main(String args[]) {
      // create an array list
      ArrayList al = new ArrayList();
      System.out.println("Initial size of al: " + al.size());

      // add elements to the array list
      al.add("C");
      al.add("A");
      al.add("E");
      al.add("B");
      al.add("D");
      al.add("F");
      al.add(1, "A2");
      System.out.println("Size of al after additions: " + al.size());

      // display the array list
      System.out.println("Contents of al: " + al);
      // Remove elements from the array list
      al.remove("F");
      al.remove(2);
      System.out.println("Size of al after deletions: " + al.size());
      System.out.println("Contents of al: " + al);
   }
}

这将产生以下结果:

Initial size of al: 0
Size of al after additions: 7
Contents of al: [C, A2, A, E, B, D, F]
Size of al after deletions: 5
Contents of al: [C, A2, E, B, D]