首頁  >  文章  >  Java  >  關於java中RandomAccess介面源碼的詳細分析

關於java中RandomAccess介面源碼的詳細分析

黄舟
黄舟原創
2017-05-28 09:06:102088瀏覽

這篇文章主要介紹了java 中RandomAccess接口源碼分析的相關資料,需要的朋友可以參考下

java 中RandomAccess接口源碼分析

RandomAccess是一個接口,位於java.util套件中。

這個介面的作用註解寫的很清楚了:

/**
 * Marker interface used by <tt>List</tt> implementations to indicate that
 * they support fast (generally constant time) random access. The primary
 * purpose of this interface is to allow generic algorithms to alter their
 * behavior to provide good performance when applied to either random or
 * sequential access lists.
 * List实现所使用的标记接口,用来表明实现了这些接口的list支持快速(通常是常数时间)随机访问。
 * 这个接口的主要目的是允许一般的算法更改它们的行为,以便在随机或者顺序存取列表时能提供更好的性能。
 * <p>The best algorithms for manipulating random access lists (such as
 * <tt>ArrayList</tt>) can produce quadratic behavior when applied to
 * sequential access lists (such as <tt>LinkedList</tt>). Generic list
 * algorithms are encouraged to check whether the given list is an
 * <tt>instanceof</tt> this interface before applying an algorithm that would
 * provide poor performance if it were applied to a sequential access list,
 * and to alter their behavior if necessary to guarantee acceptable
 * performance.
 * 操作随机访问列表(如ArrayList)的最佳算法在应用于顺序存取列表时,有可能产生二次项行为。
 * 泛型算法列表鼓励在将某个算法应用于顺序存取列表可能导致差的性能之前,先检查给定的列表是否是这个接口的一个实例,
 * 并在需要时去改变这些算法的行为以保证性能。
 * <p>It is recognized that the distinction between random and sequential
 * access is often fuzzy. For example, some <tt>List</tt> implementations
 * provide asymptotically linear access times if they get huge, but constant
 * access times in practice. Such a <tt>List</tt> implementation
 * should generally implement this interface. As a rule of thumb, a
 * <tt>List</tt> implementation should implement this interface if,
 * for typical instances of the class, this loop:

 * 随机访问和顺序存取之间的界限通常是模糊的。例如,一些List实现在变得很大时会导致渐进的非线性访问时间,但实际上是常量访问时间。
 * 这样的List实现通常都应该实现该接口。
 * 一般来说,某个List实现如果(对某些典型的类的实例来说)满足下面的条件,就应该实现这个接口:循环
 * <pre class="brush:php;toolbar:false">
 *   for (int i=0, n=list.size(); i < n; i++)
 *     list.get(i);
 * 
* runs faster than this loop: * 比下面的循环运行速度快。 *
 *   for (Iterator i=list.iterator(); i.hasNext(); )
 *     i.next();
 * 
* *

This interface is a member of the * * Java Collections Framework. * 这个接口是Java集合框架的一员。 * @since 1.4 */ public interface RandomAccess { }

 RandomAccess是一個空接口,而空介面的作用一般是起到一個標識的作用。

通俗點講,就是判斷一個list是否實現了RandomAcess接口,如果實現了,採用下面所示的簡單的for循環進行訪問速度比較快:

for (int i=0, n=list.size(); i < n; i++)
   list.get(i);

如果未實作RandomAcess接口,則採用下面的iterator循環存取速度比較快。

for (Iterator i=list.iterator(); i.hasNext(); )
   i.next();

判斷使用instanceof,即

 if (list instanceof RandomAccess)

以上是關於java中RandomAccess介面源碼的詳細分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn