jdk源码之ArrayList实现RandomAccess空架子

本文探讨了Java中RandomAccess接口的作用,它用于标识支持快速随机访问的List实现,如ArrayList。通过实例代码展示了如何利用instanceof检查List是否实现RandomAccess接口,以选择合适的遍历方式提升算法性能。对于ArrayList,使用for循环遍历更高效,而LinkedList则适合使用迭代器。
  1. ArrayList的类图

2,RandomAccess点进去只是个空架子,那么他有什么用呢?

 

JDK 官方文档是不可少的工具, 先看看它是怎么说的:RandomAccessList 实现所使用的标记接口,用来表明其支持快速(通常是固定时间)随机访问.那表示它能快速随机访问存储的元素底层是数组实现的ArrayList实现他说明太使用for循环比LinkList的for循环快.

数据支持随机访问, 查询速度快, 增删元素慢; 链表支持顺序访问, 查询速度慢, 增删元素快。所以对应的 ArrayList 查询速度快,LinkedList 查询速度慢, RandomAccess 这个标记接口就是标记能够随机访问元素的集合, 简单来说就是底层是数组实现的集合。

可利用 RandomAccess 在遍历前进行判断,根据 List 的不同子类选择不同的遍历方式, 提升算法性能。

package test.randomaccess;

import java.util.*;

public class MyTest {
    //用来判断是否实现RandomAccess接口
    public static void  traverse(List list){
        //如果实现的RandomAccess这个接口就采用for循环否则就用迭代器遍历
        if (list instanceof RandomAccess){
            System.out.println("实现了RandomAccess接口,不使用迭代器");
            long startTime = System.currentTimeMillis();
            for (int i = 0;i < list.size();i++){
                list.get(i);
            }
            long endTime = System.currentTimeMillis();
            System.out.println(list.getClass().getName()+"for循环遍历时间"+(endTime-startTime));

        }else{
            System.out.println("没实现RandomAccess接口,使用迭代器");

            Iterator iterator = list.iterator();
            long startTime = System.currentTimeMillis();
            while (iterator.hasNext()){
                iterator.next();
            }
            long endTime = System.currentTimeMillis();
            System.out.println(list.getClass().getName()+"迭代器循环遍历时间"+(endTime-startTime));

        }
    }
    public static void main(String[] args) {
        //加入数据
        List<String> arrayList = new ArrayList<>();
        for (int i = 0;i < 30000;i++){
            arrayList.add("" + i);
        }
        //先判断是否实现
       traverse(arrayList);
        List<String> linkedList = new LinkedList<>();
        //加入数据
        for (int i = 0;i < 30000;i++){
            linkedList.add("" + i);
        }
        traverse(linkedList);
    }
}

 利用instanceof可以使用他最优的效率方式去遍历数据

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ehdjsbs

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值