欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

redis數(shù)據(jù)結(jié)構(gòu)之壓縮列表

 更新時(shí)間:2022年03月21日 09:25:37   作者:周杰倫本人  
這篇文章主要介紹了redis數(shù)據(jù)結(jié)構(gòu)之壓縮列表,壓縮列表是列表list和hash數(shù)據(jù)結(jié)構(gòu)的底層實(shí)現(xiàn)之一,是redis為了節(jié)約內(nèi)存而開發(fā)的,由一系列特殊編碼的連續(xù)內(nèi)存塊組成的順序型數(shù)據(jù)結(jié)構(gòu),下面詳細(xì)內(nèi)容需要的小伙伴可以參考一下

壓縮列表是列表鍵和哈希鍵的底層實(shí)現(xiàn)之一。當(dāng)一個(gè)列表鍵只包含少量列表項(xiàng),并且每個(gè)列表項(xiàng)要么就是小整數(shù),要么就是長(zhǎng)度比較短的字符串,redis就會(huì)使用壓縮列表來(lái)做列表鍵的底層實(shí)現(xiàn)

當(dāng)一個(gè)哈希鍵只包含少量鍵值對(duì),并且每個(gè)鍵值對(duì)的鍵和值要么就是小整數(shù)值,要么就是長(zhǎng)度比較短的字符串,那么Redis就會(huì)使用壓縮列表來(lái)做哈希鍵的底層實(shí)現(xiàn)。

壓縮列表是Redis為了節(jié)約內(nèi)存而開發(fā)的是由一系列特殊編碼的連續(xù)內(nèi)存塊組成的順序型數(shù)據(jù)結(jié)構(gòu),一個(gè)壓縮列表可以包含任意多個(gè)節(jié)點(diǎn),每個(gè)節(jié)點(diǎn)可以保存一個(gè)字節(jié)數(shù)組或者一個(gè)整數(shù)值

ziplist 數(shù)據(jù)結(jié)構(gòu):壓縮列表各個(gè)組成部分

壓縮列表各個(gè)組成部分詳細(xì)說明:

壓縮列表節(jié)點(diǎn)的構(gòu)成:

每個(gè)壓縮列表節(jié)點(diǎn)可以保存一個(gè)字節(jié)數(shù)組或者一個(gè)整數(shù)值,其中字節(jié)數(shù)組可以是以下三種長(zhǎng)度的其中一種

長(zhǎng)度小于等于63字節(jié)的字節(jié)數(shù)組

長(zhǎng)度小于等于16383字節(jié)的字節(jié)數(shù)組

長(zhǎng)度小于等于4294967295字節(jié)的字節(jié)數(shù)組

數(shù)值則可以是以下六種長(zhǎng)度的其中一種:

  • 1:  4位長(zhǎng)介于0至12之間的無(wú)符號(hào)整數(shù)
  • 2:1字節(jié)長(zhǎng)的有符號(hào)整數(shù)
  • 3: 3字節(jié)長(zhǎng)的有符號(hào)整數(shù)
  • 4:int16類型整數(shù)
  • 5:int32類型整數(shù)
  • 6 : int64類型整數(shù)

壓縮列表的數(shù)據(jù)結(jié)構(gòu):

壓縮列表是redis為了節(jié)約內(nèi)存而開發(fā)的,由一系列特殊編碼的連續(xù)內(nèi)存塊組成的順序型數(shù)據(jù)結(jié)構(gòu)。一個(gè)壓縮列表可以包含任意多個(gè)節(jié)點(diǎn),每個(gè)節(jié)點(diǎn)保存一個(gè)字節(jié)數(shù)組或者一個(gè)整數(shù)值。

創(chuàng)建一個(gè)空的ziplist:

/*
?* 新創(chuàng)建一個(gè)空 ziplist
?*?
?* 復(fù)雜度:O(1)
?*
?* 返回值:新創(chuàng)建的 ziplist
?*/
unsigned char *ziplistNew(void) {
? ? // 分配 2 個(gè) 32 bit,一個(gè) 16 bit,以及一個(gè) 8 bit
? ? // 分別用于 <zlbytes><zltail><zllen> 和 <zlend>
? ? unsigned int bytes = ZIPLIST_HEADER_SIZE+1;
? ? unsigned char *zl = zmalloc(bytes);

? ? // 設(shè)置長(zhǎng)度
? ? ZIPLIST_BYTES(zl) = intrev32ifbe(bytes);

? ? // 設(shè)置表尾偏移量
? ? ZIPLIST_TAIL_OFFSET(zl) = intrev32ifbe(ZIPLIST_HEADER_SIZE);

? ? // 設(shè)置列表項(xiàng)數(shù)量
? ? ZIPLIST_LENGTH(zl) = 0;

? ? // 設(shè)置表尾標(biāo)識(shí)
? ? zl[bytes-1] = ZIP_END;

? ? return zl;
}

壓縮列表包含任意多個(gè)壓縮列表節(jié)點(diǎn),每個(gè)節(jié)點(diǎn)可以保存一個(gè)字節(jié)數(shù)組或者一個(gè)整數(shù)值。

壓縮列表組成部分:

  • zlbytes:記錄整個(gè)壓縮列表占用的內(nèi)存字節(jié)數(shù)
  • zltail:記錄壓縮列表表尾節(jié)點(diǎn)距離壓縮列表的起始地址的字節(jié)數(shù)
  • entryX:列表節(jié)點(diǎn)
  • zlend:用于標(biāo)記壓縮列表的末端

壓縮列表節(jié)點(diǎn)的構(gòu)成:

  • preivous_entry_length:記錄壓縮列表中前一個(gè)節(jié)點(diǎn)的長(zhǎng)度
  • encoding:記錄節(jié)點(diǎn)content屬性保存數(shù)據(jù)的類型以及長(zhǎng)度
  • content:負(fù)責(zé)保存節(jié)點(diǎn)的值,值的類型和長(zhǎng)度由節(jié)點(diǎn)的encoding屬性決定。

當(dāng)我們知道一個(gè)指向某個(gè)節(jié)點(diǎn)起始地址的指針,那么通過這個(gè)指針以及這個(gè)節(jié)點(diǎn)的preivous_entry_length屬性,我們可以一直向前一個(gè)節(jié)點(diǎn)回溯,最終到達(dá)壓縮列表的表頭節(jié)點(diǎn)。

連鎖更新:

每個(gè)節(jié)點(diǎn)的preivous_entry_length屬性記錄前一個(gè)節(jié)點(diǎn)的長(zhǎng)度

如果前一個(gè)節(jié)點(diǎn)長(zhǎng)度小于254字節(jié),preivous_entry_length屬性需要用1字節(jié)長(zhǎng)的空間來(lái)保存這個(gè)長(zhǎng)度值

如果前一個(gè)節(jié)點(diǎn)長(zhǎng)度大于等于254字節(jié),preivous_entry_length屬性需要用5字節(jié)長(zhǎng)的空間來(lái)保存這個(gè)長(zhǎng)度值

如果前一個(gè)節(jié)點(diǎn)長(zhǎng)度變大,這個(gè)節(jié)點(diǎn)的preivous_entry_length就要擴(kuò)展,這個(gè)節(jié)點(diǎn)的擴(kuò)展引起下一個(gè)節(jié)點(diǎn)的擴(kuò)展,這就是連鎖更新

redis將這種在特殊情況下產(chǎn)生的連續(xù)多次空間擴(kuò)展操作稱之為連鎖更新

在添加新節(jié)點(diǎn)和刪除節(jié)點(diǎn)都可能引發(fā)連鎖更新。

連鎖更新最壞情況下需要對(duì)壓縮列表進(jìn)行N次空間重分配操作,每次空間重分配的最壞復(fù)雜度為O(N),所以連鎖更新的最壞復(fù)雜度為O(N的平方),平均復(fù)雜度為O(N)

總結(jié):

壓縮列表是為了節(jié)約內(nèi)存而開發(fā)的順序型數(shù)據(jù)結(jié)構(gòu),它是列表鍵和哈希鍵的底層實(shí)現(xiàn)之一,壓縮列表可以包含多個(gè)節(jié)點(diǎn),每個(gè)節(jié)點(diǎn)可以保存一個(gè)字節(jié)數(shù)組或整數(shù)值,添加新節(jié)點(diǎn)或刪除節(jié)點(diǎn)可能引發(fā)連鎖更新操作,這種操作出現(xiàn)幾率不高。

到此這篇關(guān)于redis數(shù)據(jù)結(jié)構(gòu)之壓縮列表 的文章就介紹到這了,更多相關(guān)redis壓縮列表 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 基于Redis?zSet實(shí)現(xiàn)滑動(dòng)窗口對(duì)短信進(jìn)行防刷限流的問題

    基于Redis?zSet實(shí)現(xiàn)滑動(dòng)窗口對(duì)短信進(jìn)行防刷限流的問題

    這篇文章主要介紹了基于Redis?zSet實(shí)現(xiàn)滑動(dòng)窗口對(duì)短信進(jìn)行防刷限流,主要針對(duì)目前線上短信被腳本惡意盜刷的情況,用Redis實(shí)現(xiàn)滑動(dòng)窗口限流,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2022-02-02
  • Redis過期數(shù)據(jù)是否會(huì)被立馬刪除

    Redis過期數(shù)據(jù)是否會(huì)被立馬刪除

    這篇文章主要為大家介紹了Redis過期數(shù)據(jù)會(huì)被立馬刪除么的問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 使用百度地圖api通過redis實(shí)現(xiàn)地標(biāo)存儲(chǔ)及范圍坐標(biāo)點(diǎn)查詢功能

    使用百度地圖api通過redis實(shí)現(xiàn)地標(biāo)存儲(chǔ)及范圍坐標(biāo)點(diǎn)查詢功能

    這篇文章主要介紹了使用百度地圖api通過redis實(shí)現(xiàn)地標(biāo)存儲(chǔ)及范圍坐標(biāo)點(diǎn)查詢功能,本文通過圖文實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2021-08-08
  • Redis常用數(shù)據(jù)類型命令實(shí)例匯總

    Redis常用數(shù)據(jù)類型命令實(shí)例匯總

    這篇文章主要介紹了Redis常用數(shù)據(jù)類型命令實(shí)例匯總,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • redisson鎖tryLock的正確使用方式

    redisson鎖tryLock的正確使用方式

    這篇文章主要介紹了redisson鎖tryLock的正確使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • redistemplate下opsForHash操作示例

    redistemplate下opsForHash操作示例

    這篇文章主要為大家介紹了redistemplate下opsForHash操作示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • RedisDesktopManager遠(yuǎn)程連接redis的實(shí)現(xiàn)

    RedisDesktopManager遠(yuǎn)程連接redis的實(shí)現(xiàn)

    本文主要介紹了RedisDesktopManager遠(yuǎn)程連接redis的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • Linux 下redis5.0.0安裝教程詳解

    Linux 下redis5.0.0安裝教程詳解

    這篇文章主要介紹了Linux 下redis5.0.0安裝教程,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-10-10
  • redis中跳表zset的具體使用

    redis中跳表zset的具體使用

    Redis跳表zset是一種結(jié)合了跳表和有序集合的高效數(shù)據(jù)結(jié)構(gòu),適用于實(shí)現(xiàn)排序和大規(guī)模數(shù)據(jù)的快速查詢,本文主要介紹了redis中跳表zset的具體使用,感興趣的可以了解一下
    2024-01-01
  • k8s部署redis cluster集群的實(shí)現(xiàn)

    k8s部署redis cluster集群的實(shí)現(xiàn)

    在Kubernetes中部署Redis集群面臨挑戰(zhàn),因?yàn)槊總€(gè)Redis實(shí)例都依賴于一個(gè)配置文件,該文件可以跟蹤其他集群實(shí)例及其角色。需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-06-06

最新評(píng)論