亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java數據元素在內存中存放的方式有哪些

發布時間:2021-11-24 15:29:45 來源:億速云 閱讀:465 作者:iii 欄目:大數據

這篇文章主要介紹“java數據元素在內存中存放的方式有哪些”,在日常操作中,相信很多人在java數據元素在內存中存放的方式有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”java數據元素在內存中存放的方式有哪些”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

主要有2種存儲方式:

1、順序存儲,Random Access(Direct Access)

這種方式,相鄰的數據元素存放于相鄰的內存地址中,整塊內存地址是連續的。可以根據元素的位置直接計算出內存地址,直接進行讀取。讀取一個特定位置元素的平均時間復雜度為O(1)。正常來說,只有基于數組實現的集合,才有這種特性。Java中以ArrayList為代表。

2、鏈式存儲,Sequential Access

這種方式,每一個數據元素,在內存中都不要求處于相鄰的位置,每個數據元素包含它下一個元素的內存地址。不可以根據元素的位置直接計算出內存地址,只能按順序讀取元素。讀取一個特定位置元素的平均時間復雜度為O(n)。主要以鏈表為代表。Java中以LinkedList為代表。

實踐

Java數據集合框架中,提供了一個RandomAccess接口,該接口沒有方法,只是一個標記。通常被List接口的實現使用,用來標記該List的實現是否支持Random Access。

一個數據集合實現了該接口,就意味著它支持Random Access,按位置讀取元素的平均時間復雜度為O(1)。比如ArrayList。 而沒有實現該接口的,就表示不支持Random Access。比如LinkedList。

所以看來JDK開發者也是注意到這個問題的,那么推薦的做法就是,如果想要遍歷一個List,那么先判斷是否支持Random Access,也就是 list instanceof RandomAccess。

if (list instanceof RandomAccess) {
    //使用傳統的for循環遍歷。
} else {
    //使用Iterator或者foreach。
}

案例分析

比如: Collections.reverse(List<?> list) 對于該方法,具體實現為:

public static void reverse(List<?> list) {
        int size = list.size();
        if (size < REVERSE_THRESHOLD || list instanceof RandomAccess) {
            for (int i=0, mid=size>>1, j=size-1; i<mid; i++, j--)
                swap(list, i, j);
        } else {
            // instead of using a raw type here, it's possible to capture
            // the wildcard but it will require a call to a supplementary
            // private method
            ListIterator fwd = list.listIterator();
            ListIterator rev = list.listIterator(size);
            for (int i=0, mid=list.size()>>1; i<mid; i++) {
                Object tmp = fwd.next();
                fwd.set(rev.previous());
                rev.set(tmp);
            }
        }
    }

到此,關于“java數據元素在內存中存放的方式有哪些”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

澎湖县| 呼图壁县| 楚雄市| 嘉祥县| 庆元县| 淮北市| 襄汾县| 朝阳区| 景东| 余姚市| 措美县| 五台县| 高要市| 屯门区| 彭泽县| 东兴市| 永登县| 宜都市| 博白县| 城口县| 城固县| 岫岩| 阿合奇县| 新巴尔虎右旗| 独山县| 聂拉木县| 边坝县| 色达县| 荣昌县| 华安县| 乌审旗| 山阳县| 玉山县| 乌海市| 中山市| 长岭县| 吉木萨尔县| 云安县| 综艺| 新安县| 会宁县|