Java集合框架中支持随机访问的集合

82 阅读1分钟

在Java集合框架中,有一些集合实现了 RandomAccess 接口,该接口用于标识支持对元素进行快速、随机访问的集合。这通常是通过索引进行的,主要体现在List接口的实现类上。

1. 直接实现了 RandomAccess 接口的集合:

1.1 ArrayList: ArrayList 是一个动态数组实现,可以通过索引在常量时间内访问元素,因此直接实现了 RandomAccess 接口。

1.2 Vector: Vector 是另一个动态数组实现,类似于 ArrayList,同样支持快速随机访问,也实现了 RandomAccess 接口。

1.3 CopyOnWriteArrayList: CopyOnWriteArrayList 是线程安全的动态数组实现,适用于读多写少的场景,并且也实现了 RandomAccess 接口。

2. 需要转换为List来实现 RandomAccess 接口:

除了直接实现 RandomAccess 接口的集合外,其他集合可以通过转换为 List 来实现随机访问。这通常是通过 Arrays.asList() 方法将数组转换为 List 来实现的。

示例代码:

import java.util.Arrays;
import java.util.List;

public class RandomAccessExample {
    public static void main(String[] args) {
        // 使用 Arrays.asList() 将数组转换为 List
        Integer[] array = {1, 2, 3, 4, 5};
        List<Integer> list = Arrays.asList(array);

        // 判断 List 是否支持 RandomAccess
        if (list instanceof RandomAccess) {
            System.out.println("List supports random access");
        } else {
            System.out.println("List does not support random access");
        }
    }
}

上述代码中,通过 instanceof 操作符检查 List 是否实现了 RandomAccess 接口。在这个例子中,由于数组支持随机访问,因此转换后的 List 也支持随机访问。

总体而言,随机访问的特性对于需要频繁通过索引进行元素访问的场景非常重要,因此选择实现了 RandomAccess 接口的集合能够提高相应操作的效率。