在jdk文檔中對RandomAccess接口的定義如下: public interface RandomAccess
下面是jdk的注解翻譯
List 實現(xiàn)所使用的標記接口,用來表明其支持快速(通常是固定時間)隨機訪問。此接口的主要目的是允許一般的算法更改其行為,從而在將其應用到隨機或連續(xù)訪問列表時能提供良好的性能。
將操作隨機訪問列表的最佳算法(如 ArrayList )應用到連續(xù)訪問列表(如 LinkedList )時,可產(chǎn)生二次項的行為。如果將某個算法應用到連續(xù)訪問列表,那么在應用可能提供較差性能的算法前,鼓勵使用一般的列表算法檢查給定列表是否為此接口的一個 instanceof ,如果需要保證可接受的性能,還可以更改其行為。
現(xiàn)在已經(jīng)認識到,隨機和連續(xù)訪問之間的區(qū)別通常是模糊的。例如,如果列表很大時,某些 List 實現(xiàn)提供漸進的線性訪問時間,但實際上是固定的訪問時間。這樣的 List 實現(xiàn)通常應該實現(xiàn)此接口。
強調(diào):JDK中推薦的是對List集合盡量要實現(xiàn)RandomAccess接口
如果集合類是RandomAccess的實現(xiàn),則盡量用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上就差別很大,常用的作法就是:
要作一個判斷:
1
2
3
4
5
6
7
|
if (list instance of RandomAccess) { for ( int m = 0 ; m < list.size(); m++){} } else { Iterator iter = list.iterator(); while (iter.hasNext()){} } |
測試:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
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實現(xiàn)了RandomAccess接口" ); implRandomAccessTraverse(arraylist); //花了10ms時間 System.out.println( "LinkedList未實現(xiàn)了RandomAccess接口" ); implRandomAccessTraverse(linkedList); //花了434ms時間 System.out.println( "\nArrayList實現(xiàn)了RandomAccess接口" ); noImplRandomAccessTraverse(arraylist); //花了39ms時間 System.out.println( "LinkedList未實現(xiàn)了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); } } //有實現(xiàn)RandomAccess接口的遍歷全部數(shù)據(jù), 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時間" ); } //沒有實現(xiàn)RandomAccess接口的遍歷全部數(shù)據(jù) 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全面了解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持服務器之家。