Java接口RandomAccess全面了解

 更新时间:2016年09月07日 10:55:38   投稿:jingxian  
下面小编就为大家带来一篇Java接口RandomAccess全面了解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

在jdk文档中对RandomAccess接口的定义如下:  public interface RandomAccess

下面是jdk的注解翻译

List 实现所使用的标记接口,用来表明其支持快速(通常是固定时间)随机访问。此接口的主要目的是允许一般的算法更改其行为,从而在将其应用到随机或连续访问列表时能提供良好的性能。

将操作随机访问列表的最佳算法(如 ArrayList )应用到连续访问列表(如 LinkedList )时,可产生二次项的行为。如果将某个算法应用到连续访问列表,那么在应用可能提供较差性能的算法前,鼓励使用一般的列表算法检查给定列表是否为此接口的一个 instanceof ,如果需要保证可接受的性能,还可以更改其行为。

现在已经认识到,随机和连续访问之间的区别通常是模糊的。例如,如果列表很大时,某些 List 实现提供渐进的线性访问时间,但实际上是固定的访问时间。这样的 List 实现通常应该实现此接口。

强调:JDK中推荐的是对List集合尽量要实现RandomAccess接口

如果集合类是RandomAccess的实现,则尽量用for(int i = 0; i < size; i++) 来遍历而不要用Iterator迭代器来遍历。

反过来,如果List是Sequence List,则最好用迭代器来进行迭代。

JDK中说的很清楚,在对List特别是Huge size的List的遍历算法中,要尽量来判断是属于RandomAccess(如ArrayList)还是Sequence List (如LinkedList),因为适合RandomAccess List的遍历算法,用在Sequence List上就差别很大,常用的作法就是:

要作一个判断:

 if (list instance of RandomAccess) {
    for(int m = 0; m < list.size(); m++){}
  }else{
    Iterator iter = list.iterator();
    while(iter.hasNext()){}

  }

测试:

public class TestRandomAccess {
  @Test
  public void testTraverse() {
    ArrayList<Integer> arraylist = new ArrayList<Integer>();
    LinkedList<Integer> linkedList = new LinkedList<Integer>();
    initList(arraylist, 1000);
    initList(linkedList, 1000);

    System.out.println("ArrayList实现了RandomAccess接口");
    implRandomAccessTraverse(arraylist); //花了10ms时间
    System.out.println("LinkedList未实现了RandomAccess接口");
    implRandomAccessTraverse(linkedList); //花了434ms时间


    System.out.println("\nArrayList实现了RandomAccess接口");
    noImplRandomAccessTraverse(arraylist); //花了39ms时间
    System.out.println("LinkedList未实现了RandomAccess接口");
    noImplRandomAccessTraverse(linkedList); //花了27ms时间
  }

  private long startTime = 0;
  private long endTime = 0;
  // 初始化列表
  public void initList(List<Integer> list, int n) {
    for (int i = 0; i < n; i++) {
      list.add(i);
    }
  }

  //有实现RandomAccess接口的遍历全部数据,
  public void implRandomAccessTraverse(List list) {
    startTime = System.currentTimeMillis();
    for (int count = 0; count <= 1000; count++) {
      for (int i = 0; i < list.size(); i++) {
        list.get(i);
      }
    }
    endTime = System.currentTimeMillis();
    System.out.println("使用loop迭代一共花了" + (endTime - startTime) + "ms时间");
  }

  //没有实现RandomAccess接口的遍历全部数据
  public void noImplRandomAccessTraverse(List list) {
      startTime = System.currentTimeMillis();
      for (int count = 0; count <= 1000; count++) {
        for (Iterator itr = list.iterator(); itr.hasNext();) {
          itr.next();
        }
      }
      endTime = System.currentTimeMillis();
    System.out.println("使用Iterator迭代一共花了" + (endTime - startTime) + "ms时间");
  }

}

以上这篇Java接口RandomAccess全面了解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 浅谈SpringBoot在使用测试的时候是否需要@RunWith

    浅谈SpringBoot在使用测试的时候是否需要@RunWith

    本文主要介绍了浅谈SpringBoot在使用测试的时候是否需要@RunWith,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • Jmeter接口登录获取参数token报错问题解决方案

    Jmeter接口登录获取参数token报错问题解决方案

    这篇文章主要介绍了Jmeter接口登录获取参数token报错问题解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-07-07
  • 详解mybatis plus使用insert没有返回主键的处理

    详解mybatis plus使用insert没有返回主键的处理

    这篇文章主要介绍了详解mybatis plus使用insert没有返回主键的处理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • RabbitMQ中的Publish-Subscribe模式最佳实践记录

    RabbitMQ中的Publish-Subscribe模式最佳实践记录

    Publish/Subscribe 模式是 RabbitMQ 中一种强大且灵活的消息传递模式,适用于需要将消息广播给多个订阅者的场景,这篇文章主要介绍了RabbitMQ中的Publish-Subscribe模式,需要的朋友可以参考下
    2024-12-12
  • springboot+jwt+微信小程序授权登录获取token的方法实例

    springboot+jwt+微信小程序授权登录获取token的方法实例

    本文主要介绍了springboot+jwt+微信小程序授权登录获取token的方法实例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Android token过期刷新处理的方法示例

    Android token过期刷新处理的方法示例

    这篇文章主要介绍了Android token过期刷新处理的方法示例,本文详细的介绍了2种方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-10-10
  • SpringBoot如何使用TestEntityManager进行JPA集成测试

    SpringBoot如何使用TestEntityManager进行JPA集成测试

    TestEntityManager是Spring Framework提供的一个测试框架,它可以帮助我们进行 JPA 集成测试,在本文中,我们将介绍如何使用 TestEntityManager 进行 JPA 集成测试,感兴趣的跟着小编一起来学习吧
    2023-06-06
  • Servlet与JSP间的两种传值情况

    Servlet与JSP间的两种传值情况

    Servlet与JSP 之间的传值有两种情况:JSP -> Servlet, Servlet -> JSP,需要的朋友可以了解下
    2012-12-12
  • Windows 下安装配置 Eclipse详细教程

    Windows 下安装配置 Eclipse详细教程

    Eclipse是一款非常优秀的开源IDE,非常适合Java开发,由于支持插件技术,受到了越来越多的开发者的欢迎。配合众多令人眼花缭乱的插件,完全可以满足从企业级Java应用到手机终端Java游戏的开发。本文将带您手把手步入Eclipse的广阔天地
    2016-09-09
  • springcloud之FeignClient使用详解

    springcloud之FeignClient使用详解

    Feign是一种声明式、模板化的HTTP客户端,可以简化微服务之间的远程过程调用,通过Feign,开发者可以像调用本地方法一样调用远程服务,而无需感知这是一个HTTP请求,引入Feign后,微服务之间的调用流程更加简化,结合Ribbon实现了路由负载、超时熔断等功能
    2024-12-12

最新评论