目录
ArrayList类是一个可以动态修改的数组,不同于普通数组,它没有固定的大小限制,可以添加或删除元素,继承于 AbstractList 类,实现了List接口。

注:ArrayList是以泛型方式实现的,使用时必须先实例化
ArrayList类位于 java.util 包中,使用前需要导包
import java.util.ArrayList;
ArrayList()
无参构造方法,在调用该构造方法时,会构造一个空的线性表
ArrayList arrayList = new ArrayList<>();

ArrayList(Collection extends E> c)
利用其他Collection构建ArrayList
?是通配符,?extends E :接收的类型为E类型或是E的子类
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(); - arrayList.add(1);
- arrayList.add(2);
- arrayList.add(3);
- ArrayList
arrayList1 = new ArrayList<>(arrayList); - }
- }
ArrayList(int initialCapacity)
指定顺序表初始容量大小为 initialCapacity
- //构造一个具有5个容量的列表
- ArrayList
arrayList1 = new ArrayList<>(5);
当传入的参数小于0时,会抛出异常 IllegalArgumentException(创建的顺序表容量大小不能为负)

ArrayList可以使用add()方法来添加元素
boolean add(E e) //在线性表尾添加元素e,添加成功返回true,失败返回false
void add(int index, E e) //在index位置插入元素e
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(3); - arrayList.add(3);
- arrayList.add(4);
- arrayList.add(0,1);
- System.out.println(arrayList);//输出结果:[1,3,4]
- }
- }
E remove(int index) //删除 index 位置的元素,并返回 index 位置的元素
boolean remove(Object o) //删除第一个元素o,删除成功返回true,删除失败,返回false
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(3); - arrayList.add(3);
- arrayList.add(4);
- arrayList.add(4);
- arrayList.add(0,1);
- System.out.println(arrayList);//输出结果:[1,3,4,4]
- System.out.println(arrayList.remove(0));//输出结果:1
- Integer integer = 4;
- System.out.println(arrayList.remove(integer));//输出结果:true
- integer = 5;
- System.out.println(arrayList.remove(integer));//输出结果:false
- System.out.println(arrayList);//输出结果:[3,4]
- }
- }
E get(int index) //获取下标为 index 位置的元素
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(3); - arrayList.add(3);
- arrayList.add(4);
- arrayList.add(5);
- arrayList.add(0,1);
- Integer integer = arrayList.get(2);
- System.out.println(integer);//输出结果为5
- }
- }
arrayList中有n个元素,index的取值应在 [0,n) 之间,否则,抛出 IndexOutOfBoundsException 索引越界异常
int indexOf(Object o) //返回第一个o所在下标,o不存在于列表中则返回-1
int lastIndexOf(Object o) //返回最后一个o的下标,o不存在于列表中则返回-1
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(); - arrayList.add(3);
- arrayList.add(4);
- arrayList.add(4);
- Integer integer = 4;
- System.out.println(arrayList.indexOf(integer));//输出结果:1
- System.out.println(arrayList.lastIndexOf(integer));//输出结果:2
- integer = 0;
- System.out.println(arrayList.indexOf(integer));//输出结果:-1
- }
- }
E set(int index, E e) //将下标为 index 位置的元素修改为 e,并返回 index 位置原来的元素
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(); - arrayList.add(3);
- arrayList.add(4);
- Integer integer = arrayList.set(0,2);
- System.out.println(integer);//输出结果为3
- }
- }
boolean contains(Object o) //判断o是否在线性表中,在,返回true;不在,返回 false
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(); - arrayList.add(3);
- arrayList.add(4);
- arrayList.add(4);
- Integer integer = 4;
- System.out.println(arrayList.contains(integer));//输出结果:true
- integer = 0;
- System.out.println(arrayList.contains(integer));//输出结果:false
- }
- }
void clear() //清空线性表
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(); - arrayList.add(3);
- arrayList.add(4);
- arrayList.add(4);
- arrayList.clear();
- System.out.println(arrayList);//输出结果:[]
- }
- }
List
subList(int fromIndex, int toIndex) //截取集合中[fromIndex, toIndex)区间的元素
subList是List接口中定义的一个方法,用于返回集合中的一段,即从 fromIndex (包含该位置元素)位置,到 toIndex (不包含该位置元素)位置的元素,方法的返回值类型是List,且用ArrayList接收,否则会抛出 ClassCastException 异常。
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(); - arrayList.add(3);
- arrayList.add(4);
- arrayList.add(4);
- List
list = arrayList.subList(0,2); - System.out.println(list);//输出结果:[3,4]
- }
- }

若要用ArrayList接收方法的返回值,可以对其进行强制类型转换

ArrayList可以使用三种方式进行遍历,分别是 for循环、foreach 和 迭代器
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(); - arrayList.add(3);
- arrayList.add(4);
- arrayList.add(4);
- arrayList.add(5);
- for (int i = 0; i < arrayList.size(); i++) {
- System.out.print(arrayList.get(i) + " ");
- }
- }
- }
foreach中第一个参数是数组元素或集合元素的类型,i是形参名, 第二个参数是数组或集合,foreach自动将数组或集合元素依次赋值给变量i,当每个元素都被迭代一次后,foreach自动结束循环
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(); - arrayList.add(3);
- arrayList.add(4);
- arrayList.add(4);
- arrayList.add(5);
- for (Integer i: arrayList) {
- System.out.print(i + " ");
- }
- }
- }
Iterator对象称为迭代器,用于遍历集合中的元素,实现了Collection接口的集合类都有一个 iterator() 方法,用于返回一个实现了Iterator接口的对象
Iterator接口的方法:
hasNext():是否有下一个元素,有则返回true;没有则返回false
next():返回迭代的下一个元素
- public class Test {
- public static void main(String[] args) {
- ArrayList
arrayList = new ArrayList<>(); - arrayList.add(3);
- arrayList.add(4);
- arrayList.add(4);
- arrayList.add(5);
- Iterator
iterator = arrayList.iterator(); - while (iterator.hasNext()){
- System.out.print(iterator.next() + " ");
- }
- }
- }