您的位置:

ArrayList详解

一、ArrayList概述

在Java中,ArrayList是一个实现了List接口的动态数组。与Java中的数组相比,它的容量可以根据需要自动增加或减少,并且支持动态插入、删除等操作。ArrayList是常用的集合类之一,提供了便利的添加、删除和查找方法。

二、ArrayList常用方法

1. 添加元素

在ArrayList中添加元素的方法有两种:add()和addAll()。其中,add()方法可以在列表的末尾添加单个元素,addAll()方法则可以添加多个元素。

ArrayList list = new ArrayList<>();
list.add("Apple");
list.add("Orange");
 
ArrayList
    list2 = new ArrayList<>();
list2.add("Banana");
list2.add("Pineapple");
 
// 添加单个元素
list.add("Grape");
 
// 添加多个元素
list.addAll(list2);

   
  

2. 删除元素

在ArrayList中删除元素的方法有:remove()和removeAll()。其中,remove()方法可以根据元素的下标或元素本身进行删除操作,removeAll()则可以删除列表中出现在指定集合中的所有元素。

ArrayList list = new ArrayList<>();
list.add("Apple");
list.add("Orange");
list.add("Banana");
list.add("Pineapple");
list.add("Grape");
 
// 根据下标删除元素
list.remove(0);
 
// 根据元素本身删除元素
list.remove("Banana");
 
// 删除指定集合中出现的元素
ArrayList
    list2 = new ArrayList<>();
list2.add("Pineapple");
list2.add("Grape");
list.removeAll(list2);

   
  

3. 修改元素

在ArrayList中修改元素的方法是set()。它可以根据元素的下标修改元素的值。

ArrayList list = new ArrayList<>();
list.add("Apple");
list.add("Orange");
list.add("Banana");
list.add("Pineapple");
list.add("Grape");
 
// 修改元素
list.set(1, "Pear");

  

4. 查找元素

在ArrayList中查找元素的方法有两种:get()和indexOf()。其中,get()方法可以根据下标获取指定位置的元素,indexOf()则可以根据元素的值查找元素在列表中的位置。

ArrayList list = new ArrayList<>();
list.add("Apple");
list.add("Orange");
list.add("Banana");
list.add("Pineapple");
list.add("Grape");
 
// 根据下标获取元素
String fruit1 = list.get(1);
 
// 根据元素值查找元素在列表中的位置
int index = list.indexOf("Banana");

  

三、扩容机制

ArrayList内部使用动态数组实现,当数组长度不够时,需要扩容。ArrayList中的默认初始容量为10,每次扩容时容量都会翻倍。当列表元素个数超过当前容量和负载因子的乘积时,会自动进行扩容操作。

ArrayList list = new ArrayList<>();
 
for (int i = 0; i < 100; i++) {
    list.add(i);
}

  

四、性能优化

ArrayList在元素数据量较大的情况下,性能会受到一定程度的影响。以下是对ArrayList的几点性能优化建议。

1. 初始化容量

当知道ArrayList中元素数量的大致范围时,可以使用带参构造函数来指定初始容量。这有助于减少频繁的扩容操作,提高性能。

// 初始化容量为50
ArrayList list = new ArrayList<>(50);

  

2. 使用subList()方法避免拷贝

在对ArrayList进行分割时,可能需要将列表拷贝到另一个ArrayList中。这种方式会占用大量内存,在数据量较大时尤其明显。使用subList()方法可以省去拷贝操作,提高性能。

ArrayList list = new ArrayList<>();
 
for (int i = 0; i < 100; i++) {
    list.add(i);
}
 
// 获取子列表操作
List
    subList = list.subList(0, 50);

   
  

3. 使用迭代器遍历元素

在对ArrayList进行遍历操作时,使用迭代器可以减少内存占用和提高性能。同时,使用迭代器可以保证数据的安全性,避免在多线程环境下出现并发问题。

ArrayList list = new ArrayList<>();
 
for (int i = 0; i < 100; i++) {
    list.add(i);
}
 
// 使用迭代器遍历元素
Iterator
    it = list.iterator();
 
while (it.hasNext()) {
    int num = it.next();
    System.out.println(num);
}