Redis數(shù)組和鏈表深入詳解
1.數(shù)組和鏈表基礎知識
數(shù)組:
數(shù)組會在內存中開辟一塊連續(xù)的空間存儲數(shù)據,這種存儲方式有利也有弊端。當獲取數(shù)據的時候,直接通過下標值就可以獲取到對應的元素,時間復雜度為O(1)。但是如果新增或者刪除數(shù)據會移動大量的數(shù)據,時間復雜度為O(n)。數(shù)組的擴容機制是:如果數(shù)組空間不足,會先開辟一塊新的空間地址,將原來的數(shù)組復制到新的數(shù)組中。
鏈表:
鏈表不需要開辟連續(xù)的內存空間,其通過指針將所有的數(shù)據連接起來。新增或者刪除的時候只需要將指針指向的地址修改就行了,時間復雜度為O(1)。但是查詢的時間復雜度為O(n)。
2、鏈表
2.1、雙向鏈表
雙向鏈表是各個節(jié)點之間的邏輯關系是雙向的。
雙向鏈表中節(jié)點的組成是:prior:
指向當前節(jié)點的前置節(jié)點,data:
當前節(jié)點存儲的數(shù)據。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ù)據項先后順序的列表,而且數(shù)據項保存在一個連續(xù)的內存塊種。
3、對比
3.1、雙向鏈表
- 雙端鏈表便于在表的兩端進行push和pop操作,但是它的內存開銷比較大。
- 雙端鏈表每個節(jié)點上除了要保存的數(shù)據之外,還要額外保存兩個指針。
- 雙端鏈表的各個節(jié)點是單獨的內存塊,地址不連續(xù),節(jié)點多了容易產生內存碎片。
3.2、壓縮列表
- ziplist由于是一塊連續(xù)的內存,所以存儲效率很高。
- ziplist不利于修改操作,每次數(shù)據變動都會引發(fā)一次內存的realloc。
- 當ziplist長度很長的時候,一次realloc可能會導致大批量的數(shù)據拷貝,進一步降低性能。
3.3、quicklist鏈表
- 空間效率和時間效率的折中。
- 結合了雙端鏈表和壓縮列表的優(yōu)點。
4、總結
在redis 3.2版本之前使用的是 雙向鏈表和壓縮鏈表 兩種,因為雙向鏈表占用的內存要比壓縮鏈表高,所以創(chuàng)建鏈表時首先會創(chuàng)建壓縮鏈表,在合適的時機會轉化成雙向鏈表。redis 3.2之后使用的是quicklist鏈表。
到此這篇關于Redis數(shù)組和鏈表深入詳解的文章就介紹到這了,更多相關Redis數(shù)組和鏈表內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
一文詳解Redis在Ubuntu系統(tǒng)上的安裝步驟
安裝redis在Ubuntu上有多種方法,下面這篇文章主要給大家介紹了關于Redis在Ubuntu系統(tǒng)上安裝的相關資料,文中通過圖文以及代碼介紹的非常詳細,需要的朋友可以參考下2024-07-07Redis對批量數(shù)據實現(xiàn)分布式鎖的實現(xiàn)代碼
為了防止多人多電腦同時操作一條數(shù)據,我們自己開發(fā)了一個簡單的基于Redis實現(xiàn)的分布式鎖,Redis對批量數(shù)據實現(xiàn)分布式鎖相關知識感興趣的朋友一起看看吧2022-03-03Redis優(yōu)化token校驗主動失效的實現(xiàn)方案
在普通的token頒發(fā)和校驗中 當用戶發(fā)現(xiàn)自己賬號和密碼被暴露了時修改了登錄密碼后舊的token仍然可以通過系統(tǒng)校驗直至token到達失效時間,所以系統(tǒng)需要token主動失效的一種能力,所以本文給大家介紹了Redis優(yōu)化token校驗主動失效的實現(xiàn)方案,需要的朋友可以參考下2024-03-03