ArrayList 是实现了List接口的动态数组,ArrayList可以在运行时根据需要自动进行扩展大小,无需手动管理数组大小。
ArrayList的特点:
- 允许存储任意类型的对象,包括基本数据类型的包装类和自定义对象
- 可以动态添加或删除元素,列表的大小会根据需要自动调整
- 提供了丰富的方法来操作和查询列表中的元素
ArrayList<String> names = new ArrayList<>();
ArrayList<String> names2 = new ArrayList<>(30); // 创建对象时,指定集合容量
在当前集合的末尾添加元素 public boolean add(E e)
names.add("jack");
names.add("tom");
names.add("robin");
在指定索引位置,添加元素 public void add(int index, E element)
names.add(1,"sun");
通过索引获取元素 public E get(int index)
String s = names.get(1);// 获取索引为1的元素,即获取第二个元素
根据元素值进行删除 public boolean remove(Object o)
names.remove("tom");
根据索引进行删除 public E remove(int index)
names.remove(1);
获取集合的大小容量 public int size()
int size = names.size();
传统for循环遍历
for(int i=0;i<names.size();i++){
System.out.println(names.get(i));
}
for each 循环
for(String item : names){
System.out.println(item);
}
迭代器循环
Java Iterator(迭代器)不是一个集合,它是一种用于访问集合的方法,可用于迭代 ArrayList 和 HashSet 等集合。
迭代器中需要注意的3个方法:
boolean hasNext()
用于判断集合中是否还有下一个元素可以访问。E next()
返回迭代器的下一个元素,并且将迭代器的指针移动到下一个位置remove()
从集合中删除迭代器最后访问的元素—遍历时删除元素,优先选择迭代器删除,更加安全Iterator<String> iterator = names.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
names.set(0,"ZhangHang");
names.contains("ZhangHang");
boolean isEmpty = names.isEmpty();
names.containsAll(List.of("a","b","c")); // list.of(参数列表) 列表初始化,初始化内容为参数列表
ArrayList<String> addArr = new ArrayList<String>();
addArr.add("lisi");
addArr.add("ZhaoZiLong");
addArr.add("GuanYu");
names.addAll(addArr);
ArrayList<String> toRemove = new ArrayList<>();
toRemove.add("robin");
toRemove.add("ZhaoZiLong");
names.removeAll(toRemove);
ArrayList<String> toRetain = new ArrayList<>();
toRetain.add("GuanYu");
toRetain.add("lisi");
names.retainAll(toRetain);
String[] namesArray = names.toArray(new String[0]);
names.subList(0,1); // 起始索引,结束索引
names.indexOf("GuanYu");
ArrayList<String> clone = (ArrayList<String>)names.clone();
names.clear();
确保容量
names.ensureCapacity(18);
缩减容量,缩减容量至当前ArrayList的大小
names.trimToSize();
ArrayList 不是线程安全的,因此在多线程环境中访问和修改 ArrayList 可能导致数据不一致和并发问题。如果需要在线程之间共享 ArrayList,请考虑使用线程安全的集合,如 java.util.concurrent.CopyOnWriteArrayList
。
ArrayList 会动态调整其容量,但这可能会导致性能下降。如果你知道列表的最大大小,可以在初始化时指定初始容量,以减少动态扩展的次数,从而提高性能。
在 ArrayList 中删除元素时,特别是在中间位置,会涉及到后续元素的移动操作,可能会导致性能下降。如果需要频繁执行删除操作,考虑使用其他数据结构,如 LinkedList。
在使用 for-each 循环遍历 ArrayList 时,不要在循环内修改列表的内容,否则可能会抛出 ConcurrentModificationException
异常。如果需要在遍历过程中修改元素,请使用迭代器,并通过迭代器的 remove() 方法进行安全的删除操作
ArrayList 允许存储 null 值,但要小心处理它们,以免引发空指针异常。
了解 ArrayList 的性能特性,并根据实际需求选择合适的数据结构。例如,ArrayList 适用于大量读取操作,但对于大量插入和删除操作,LinkedList 可能更合适。