Java中的CopyOnWriteArrayList类


类声明

public class CopyOnWriteArrayList
   extends Object
implements List, RandomAccess, Cloneable, Serializable
  • CopyOnWriteArrayList是ArrayList的线程安全变体,其中可以更改ArrayList的操作(添加、更新、设置方法)会创建底层数组的克隆。

  • CopyOnWriteArrayList应该在基于线程的环境中使用,在该环境中读取操作非常频繁,而更新操作很少。

  • CopyOnWriteArrayList的迭代器永远不会抛出ConcurrentModificationException异常。

  • 对CopyOnWriteArrayList的任何类型的修改都不会在迭代器创建后反映在迭代过程中。

  • 在迭代过程中不支持remove、set和add之类的列表修改方法。此方法将抛出UnsupportedOperationException异常。

  • 可以将null添加到列表中。

CopyOnWriteArrayList方法

以下是CopyOnWriteArrayList类中一些重要方法的列表。

序号
方法和描述
1
void add(int index, Object element)

在此列表的指定位置index插入指定的元素。如果指定的索引超出范围 (index ≥ size()),则抛出IndexOutOfBoundsException异常。

2
boolean add(Object o)

将指定的元素追加到此列表的末尾。

3
boolean addAll(Collection c)

按指定集合的迭代器返回的顺序,将指定集合中的所有元素追加到此列表的末尾。如果指定的集合为null,则抛出NullPointerException异常。

4
boolean addAll(int index, Collection c)

从指定位置开始,将指定集合中的所有元素插入到此列表中。如果指定的集合为null,则抛出NullPointerException异常。

5
void clear()

从此列表中删除所有元素。

6
Object clone()

返回此ArrayList的浅拷贝。

7
boolean contains(Object o)

如果此列表包含指定的元素,则返回true。更正式地说,当且仅当此列表至少包含一个元素e,使得(o==null ? e==null : o.equals(e))时,返回true。

8
Object get(int index)

返回此列表中指定位置的元素。如果指定的索引超出范围 (index ≥ size()),则抛出IndexOutOfBoundsException异常。

9
int indexOf(Object o)

返回此列表中指定元素的第一次出现的索引,如果列表不包含此元素,则返回-1。

10
int lastIndexOf(Object o)

返回此列表中指定元素的最后一次出现的索引,如果列表不包含此元素,则返回-1。

11
Object remove(int index)

从此列表中删除指定位置的元素。如果索引超出范围 (index ≥ size()),则抛出IndexOutOfBoundsException异常。

12
Object set(int index, Object element)

将此列表中指定位置的元素替换为指定的元素。如果指定的索引超出范围 (index ≥ size()),则抛出IndexOutOfBoundsException异常。

13
int size()

返回此列表中元素的数量。

14
Object[] toArray()

返回一个包含此列表中所有元素的数组,顺序正确。如果指定的数组为null,则抛出NullPointerException异常。


示例

以下程序演示了ArrayList支持的几种方法:

在线演示

import java.util.Iterator;
import java.util.concurrent.CopyOnWriteArrayList;
public class Tester {

   public static void main(String args[]) {
      // create an array list
      CopyOnWriteArrayList al = new CopyOnWriteArrayList();
      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);

      try {
         Iterator iterator = al.iterator();
         while(iterator.hasNext()) {
            iterator.remove();
         }
      }catch(UnsupportedOperationException e) {
         System.out.println("Method not supported:");
      }
      System.out.println("Size of al: " + al.size());
   }
}

这将产生以下结果:

输出

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]
Method not supported:
Size of al: 5

更新于:2020年6月19日

4K+ 次浏览

启动你的职业生涯

完成课程获得认证

开始学习
广告