当前位置: 首页 > 编程笔记 >

Java接口RandomAccess全面了解

巫培
2023-03-14
本文向大家介绍Java接口RandomAccess全面了解,包括了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全面了解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍RandomAccess接口?相关面试题,主要包含被问及RandomAccess接口?时的应答技巧和注意事项,需要的朋友参考一下 查看源码我们发现实际上 接口中什么都没有定义。所以,在我看来 接口不过是一个标识罢了。标识什么? 标识实现这个接口的类具有随机访问功能。 在 )方法中,它要判断传入的list 是否 的实例,如果是,调用方法,如果不是,那么调用方法 实现了 接口, 而 没有

  • 本文向大家介绍java 中RandomAccess接口源码分析,包括了java 中RandomAccess接口源码分析的使用技巧和注意事项,需要的朋友参考一下 java 中RandomAccess接口源码分析 RandomAccess是一个接口,位于java.util包中。 这个接口的作用注释写的很清楚了:  RandomAccess是一个空接口,而空接口的作用一般是起到一个标识的作用。 通俗点讲

  • 问题内容: 实现接口。接口没有方法。当我检查它没有实现接口。 那么,在实现的意义何在? 问题答案: 没有方法的接口在Java中称为标记接口。 根据RandomAccess的JavaDoc: List实现使用的标记接口,指示 它们支持快速(通常为恒定时间)随机访问。 有关更多信息,请检查两个JavaDoc页面。 http://docs.oracle.com/javase/6/docs/api/jav

  • 问题内容: 我必须实现一个RMI服务器,该服务器将成为其他两个RMI服务的前端。因此,我决定逻辑上要做的是使该接口实现其他两个服务的接口。 但是,StudentServer上有一种方法 我也想抛出一个错误,因为该服务还将在尝试添加详细信息之前验证该书是否确实存在。 这是可能的还是我的设计思想完全被取消了,实际上这是一个糟糕的设计思想,好像其他接口都已更改一样?而且,为里面的所有方法编写方法签名会更

  • 本文向大家介绍全面了解Java中的CAS机制,包括了全面了解Java中的CAS机制的使用技巧和注意事项,需要的朋友参考一下 前言 在看到Java锁机制的时候,无意中看到了CAS这个词,然后在百度查找CAS看了很多文章始终没有看的太懂,今天又在Google上查找了一些资料,才算是真正弄清楚了CAS机制。 什么是CAS 在jdk 1.5中增加的一个最主要的支持是Atomic类,比如说AtomicInt

  • 我对一些基本的Spring数据概念有点困惑。 据我所知,典型的DAO级别结构如下所示: 有了这个概念,我可以使用JPA作为第一个DAO接口的实现,使用JDBC作为第二个DAO接口的实现。 现在我想了解Spring存储库抽象。每个Spring Data tutorial都指定,我应该有一个接口,例如,该接口应该从JPararePository扩展。所以有了这个接口,我已经用JPA锁定了,对吧? 如果

  • 问题内容: 一般而言,我真的需要帮助… 你们会推荐我任何资源吗? 问题答案: 什么是接口?来自Java的官方教程 编辑:同一教程的第二个资源是“ 接口和继承”部分。

  • 主要内容:定义接口,实现接口抽象类是从多个类中抽象出来的模板,如果将这种抽象进行的更彻底,则可以提炼出一种更加特殊的“抽象类”—— 接口(Interface)。接口是 Java 中最重要的概念之一,它可以被理解为一种特殊的类,不同的是 接口的成员没有执行体,是由全局常量和公共的抽象方法所组成。 定义接口 Java 接口的定义方式与类基本相同,不过接口定义使用的关键字是 interface,接口定义的语法格式如下: 对以上语法