佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > Redis數(shù)組和鏈表深入詳解

Redis數(shù)組和鏈表深入詳解

熱門標簽:百度競價排名 Linux服務器 鐵路電話系統(tǒng) AI電銷 地方門戶網站 網站排名優(yōu)化 服務外包 呼叫中心市場需求

1.數(shù)組和鏈表基礎知識

數(shù)組
數(shù)組會在內存中開辟一塊連續(xù)的空間存儲數(shù)據(jù),這種存儲方式有利也有弊端。當獲取數(shù)據(jù)的時候,直接通過下標值就可以獲取到對應的元素,時間復雜度為O(1)。但是如果新增或者刪除數(shù)據(jù)會移動大量的數(shù)據(jù),時間復雜度為O(n)。數(shù)組的擴容機制是:如果數(shù)組空間不足,會先開辟一塊新的空間地址,將原來的數(shù)組復制到新的數(shù)組中。

鏈表
鏈表不需要開辟連續(xù)的內存空間,其通過指針將所有的數(shù)據(jù)連接起來。新增或者刪除的時候只需要將指針指向的地址修改就行了,時間復雜度為O(1)。但是查詢的時間復雜度為O(n)。

2、鏈表

2.1、雙向鏈表

雙向鏈表是各個節(jié)點之間的邏輯關系是雙向的。
雙向鏈表中節(jié)點的組成是:prior: 指向當前節(jié)點的前置節(jié)點,data:當前節(jié)點存儲的數(shù)據(jù)。next:指向當前節(jié)點的后置節(jié)點。

2.2、壓縮鏈表

  • 壓縮鏈表是為了節(jié)約內存開發(fā)的。
  • ziplist是一個特別的雙向鏈表,沒有維護雙向指針prev next;反而是存儲上一個entry的長度和當前entry長度,通過長度推算出下一個元素在什么地方。
  • 犧牲讀取的性能,獲得高效的存儲空間,因為存儲指針比存儲entry長度更費內存,這就是典型的時間換空間。

2.3、quicklist鏈表

  • 官網介紹:
A doubly linked list of ziplists
A generic doubly linked quicklist implementation
  • 介紹:

quicklist是一個雙向鏈表,并且是一個ziplist的雙向鏈表,ziplist本身是一個維持數(shù)據(jù)項先后順序的列表,而且數(shù)據(jù)項保存在一個連續(xù)的內存塊種。

3、對比

3.1、雙向鏈表

  • 雙端鏈表便于在表的兩端進行push和pop操作,但是它的內存開銷比較大。
  • 雙端鏈表每個節(jié)點上除了要保存的數(shù)據(jù)之外,還要額外保存兩個指針。
  • 雙端鏈表的各個節(jié)點是單獨的內存塊,地址不連續(xù),節(jié)點多了容易產生內存碎片。

3.2、壓縮列表

  • ziplist由于是一塊連續(xù)的內存,所以存儲效率很高。
  • ziplist不利于修改操作,每次數(shù)據(jù)變動都會引發(fā)一次內存的realloc。
  • 當ziplist長度很長的時候,一次realloc可能會導致大批量的數(shù)據(jù)拷貝,進一步降低性能。

3.3、quicklist鏈表

  • 空間效率和時間效率的折中。
  • 結合了雙端鏈表和壓縮列表的優(yōu)點。

4、總結

在redis 3.2版本之前使用的是 雙向鏈表和壓縮鏈表 兩種,因為雙向鏈表占用的內存要比壓縮鏈表高,所以創(chuàng)建鏈表時首先會創(chuàng)建壓縮鏈表,在合適的時機會轉化成雙向鏈表。redis 3.2之后使用的是quicklist鏈表。

到此這篇關于Redis數(shù)組和鏈表深入詳解的文章就介紹到這了,更多相關Redis數(shù)組和鏈表內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python實現(xiàn)隊列的方法示例小結【數(shù)組,鏈表】
  • Python實現(xiàn)棧的方法詳解【基于數(shù)組和單鏈表兩種方法】
  • JavaScript將數(shù)組轉換為鏈表的方法
  • 使用python實現(xiàn)數(shù)組、鏈表、隊列、棧的方法
  • php數(shù)組和鏈表的區(qū)別總結
  • java使用數(shù)組和鏈表實現(xiàn)隊列示例
  • 兩路歸并的數(shù)組與鏈表的實現(xiàn)方法

標簽:仙桃 崇左 銅川 黃山 蘭州 湘潭 湖南 衡水

巨人網絡通訊聲明:本文標題《Redis數(shù)組和鏈表深入詳解》,本文關鍵詞  ;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    贺州市| 大庆市| 湘阴县| 大埔区| 阿克苏市| 托克逊县| 山丹县| 晋宁县| 元朗区| 瓮安县| 芦溪县| 建湖县| 塔城市| 新兴县| 仲巴县| 汤原县| 黄陵县| 平原县| 永泰县| 疏勒县| 岳阳县| 蕉岭县| 清河县| 邢台县| 孙吴县| 蛟河市| 海林市| 南城县| 宁海县| 佛教| 辽阳县| 泽州县| 合阳县| 云浮市| 东乌珠穆沁旗| 襄垣县| 苏尼特右旗| 二手房| 石景山区| 泰宁县| 蕲春县|