Java接口RandomAccess全面了解

在jdk文檔中對RandomAccess接口的定義如下: public interface RandomAccess
下面是jdk的注解翻譯
List 實現(xiàn)所使用的標(biāo)記接口,用來表明其支持快速(通常是固定時間)隨機訪問。此接口的主要目的是允許一般的算法更改其行為,從而在將其應(yīng)用到隨機或連續(xù)訪問列表時能提供良好的性能。
將操作隨機訪問列表的最佳算法(如 ArrayList )應(yīng)用到連續(xù)訪問列表(如 LinkedList )時,可產(chǎn)生二次項的行為。如果將某個算法應(yīng)用到連續(xù)訪問列表,那么在應(yīng)用可能提供較差性能的算法前,鼓勵使用一般的列表算法檢查給定列表是否為此接口的一個 instanceof ,如果需要保證可接受的性能,還可以更改其行為。
現(xiàn)在已經(jīng)認(rèn)識到,隨機和連續(xù)訪問之間的區(qū)別通常是模糊的。例如,如果列表很大時,某些 List 實現(xiàn)提供漸進的線性訪問時間,但實際上是固定的訪問時間。這樣的 List 實現(xiàn)通常應(yīng)該實現(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上就差別很大,常用的作法就是:
要作一個判斷:
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實現(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)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
淺談SpringBoot在使用測試的時候是否需要@RunWith
本文主要介紹了淺談SpringBoot在使用測試的時候是否需要@RunWith,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01
Jmeter接口登錄獲取參數(shù)token報錯問題解決方案
這篇文章主要介紹了Jmeter接口登錄獲取參數(shù)token報錯問題解決方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-07-07
詳解mybatis plus使用insert沒有返回主鍵的處理
這篇文章主要介紹了詳解mybatis plus使用insert沒有返回主鍵的處理,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
RabbitMQ中的Publish-Subscribe模式最佳實踐記錄
Publish/Subscribe 模式是 RabbitMQ 中一種強大且靈活的消息傳遞模式,適用于需要將消息廣播給多個訂閱者的場景,這篇文章主要介紹了RabbitMQ中的Publish-Subscribe模式,需要的朋友可以參考下2024-12-12
springboot+jwt+微信小程序授權(quán)登錄獲取token的方法實例
本文主要介紹了springboot+jwt+微信小程序授權(quán)登錄獲取token的方法實例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
SpringBoot如何使用TestEntityManager進行JPA集成測試
TestEntityManager是Spring Framework提供的一個測試框架,它可以幫助我們進行 JPA 集成測試,在本文中,我們將介紹如何使用 TestEntityManager 進行 JPA 集成測試,感興趣的跟著小編一起來學(xué)習(xí)吧2023-06-06

