Java接口RandomAccess全面了解
在jdk文檔中對RandomAccess接口的定義如下: public interface RandomAccess
下面是jdk的注解翻譯
List 實(shí)現(xiàn)所使用的標(biāo)記接口,用來表明其支持快速(通常是固定時(shí)間)隨機(jī)訪問。此接口的主要目的是允許一般的算法更改其行為,從而在將其應(yīng)用到隨機(jī)或連續(xù)訪問列表時(shí)能提供良好的性能。
將操作隨機(jī)訪問列表的最佳算法(如 ArrayList )應(yīng)用到連續(xù)訪問列表(如 LinkedList )時(shí),可產(chǎn)生二次項(xiàng)的行為。如果將某個(gè)算法應(yīng)用到連續(xù)訪問列表,那么在應(yīng)用可能提供較差性能的算法前,鼓勵(lì)使用一般的列表算法檢查給定列表是否為此接口的一個(gè) instanceof ,如果需要保證可接受的性能,還可以更改其行為。
現(xiàn)在已經(jīng)認(rèn)識到,隨機(jī)和連續(xù)訪問之間的區(qū)別通常是模糊的。例如,如果列表很大時(shí),某些 List 實(shí)現(xiàn)提供漸進(jìn)的線性訪問時(shí)間,但實(shí)際上是固定的訪問時(shí)間。這樣的 List 實(shí)現(xiàn)通常應(yīng)該實(shí)現(xiàn)此接口。
強(qiáng)調(diào):JDK中推薦的是對List集合盡量要實(shí)現(xiàn)RandomAccess接口
如果集合類是RandomAccess的實(shí)現(xiàn),則盡量用for(int i = 0; i < size; i++) 來遍歷而不要用Iterator迭代器來遍歷。
反過來,如果List是Sequence List,則最好用迭代器來進(jìn)行迭代。
JDK中說的很清楚,在對List特別是Huge size的List的遍歷算法中,要盡量來判斷是屬于RandomAccess(如ArrayList)還是Sequence List (如LinkedList),因?yàn)檫m合RandomAccess List的遍歷算法,用在Sequence List上就差別很大,常用的作法就是:
要作一個(gè)判斷:
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實(shí)現(xiàn)了RandomAccess接口"); implRandomAccessTraverse(arraylist); //花了10ms時(shí)間 System.out.println("LinkedList未實(shí)現(xiàn)了RandomAccess接口"); implRandomAccessTraverse(linkedList); //花了434ms時(shí)間 System.out.println("\nArrayList實(shí)現(xiàn)了RandomAccess接口"); noImplRandomAccessTraverse(arraylist); //花了39ms時(shí)間 System.out.println("LinkedList未實(shí)現(xiàn)了RandomAccess接口"); noImplRandomAccessTraverse(linkedList); //花了27ms時(shí)間 } 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); } } //有實(shí)現(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時(shí)間"); } //沒有實(shí)現(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時(shí)間"); } }
以上這篇Java接口RandomAccess全面了解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java實(shí)現(xiàn)多線程斷點(diǎn)下載實(shí)例代碼(下載過程中可以暫停)
線程可以理解為下載的通道,一個(gè)線程就是一個(gè)文件的下載通道,多線程也就是同時(shí)開啟好幾個(gè)下載通道,Java實(shí)現(xiàn)多線程斷點(diǎn)下載實(shí)例代碼(下載過程中可以暫停),有興趣的可以了解一下。2016-12-12java數(shù)組及arrays類對數(shù)組的操作實(shí)例
下面小編就為大家?guī)硪黄猨ava數(shù)組及arrays類對數(shù)組的操作實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10dubbo服務(wù)引用之創(chuàng)建Invoker流程詳解
這篇文章主要為大家介紹了dubbo服務(wù)引用二之創(chuàng)建Invoker流程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08SSM框架通過mybatis-generator自動(dòng)生成代碼(推薦)
這篇文章主要介紹了SSM框架通過mybatis-generator自動(dòng)生成代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2017-11-11ssh框架實(shí)現(xiàn)文件上傳下載實(shí)例代碼
本篇文章主要介紹了ssh框架文件上傳下載實(shí)例代碼,實(shí)例分析了Spring+struts+Hibernate的使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。2017-03-03Zookeeper如何實(shí)現(xiàn)分布式服務(wù)配置中心詳解
Zookeeper在實(shí)際使用場景很多,比如配置中心,分布式鎖,注冊中心等,下面這篇文章主要給大家介紹了關(guān)于Zookeeper如何實(shí)現(xiàn)分布式服務(wù)配置中心的相關(guān)資料,需要的朋友可以參考下2021-11-11SpringBoot 集成 Jasypt 對數(shù)據(jù)庫加密以及踩坑的記錄分享
這篇文章主要介紹了SpringBoot 集成 Jasypt 對數(shù)據(jù)庫加密以及踩坑,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08關(guān)于Jmeter接口測試實(shí)戰(zhàn)-Cookies
這篇文章主要介紹了關(guān)于Jmeter接口測試實(shí)戰(zhàn)-Cookies問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03