Redis有序集合對象

一.編碼

? ? ? ? 有序集合的編碼可以是ziplist或者skiplist。

? ? ? ? ziplist編碼的有序集合對象使用壓縮列表作為底層實現,每一個集合元素使用緊挨在一起的兩個壓縮列表節點來保存。第一個節點保存元素的成員(member),而第二個元素則保存元素的分值(score)。

127.0.0.1:6379> zadd price 8.5 apple 5.0 banana 6.0 cherry
(integer) 3
  • 使用ziplist壓縮列表編碼?

如果price鍵的值對象使用的是ziplist編碼,那么這個值的對象和壓縮列表如下圖:

注意:Redis5.0版本后使用listpack替代了ziplist?Redis哈希對象(listpack介紹)-CSDN博客

  • 使用skiplist編碼?

? ? ? ? ?skiplist編碼的有序集合對象使用zset結構作為底層實現,一個zset結構同時包含一個字典和一個跳躍表。字典和跳躍表都會使用到。

typedef struct zset {dict *dict;zskiplist *zsl;
} zset;

? ? ? ? zset結構中的zsl跳躍表按分值從小到大保存了所有集合元素,每一個跳躍表節點保存了一個集合元素:跳躍表的節點的object屬性保存了元素的成員,而跳躍表節點的score屬性則保存了元素的分值。通過這個跳躍表,程序程序可以對有序集合進行范圍查詢操作,比如:zrank,zrange等命令就是基于跳躍表的API實現的。

? ? ? ? 而zset結構中的dict字典為有序集合創建了一個成員到分值的映射,字典中的每一個鍵值對都保存了一個集合元素:字典中的鍵保存了元素成員,而字典中的值保存了元素的分值。通過這個字典,程序可以通過O(1)復雜度查找給定成員的分值,zscore命令就是根據這一特性實現的。而很多其他有序集合的命令都是通過這一特性實現的。

? ? ? ? 有序集合每一個成員都是一個字符串對象,而每一個元素的分值都是一個double類型的浮點數。

? ? ? ? 雖然zset結構同時使用跳躍表和字典來保存有序集合元素,但這兩種數據結構都通過指針來共享相同元素的成員和分值,所以同時使用跳躍表和字典老保存有序集合元素不會產生任何重復成員和分值,也不會因此而浪費額外的內存。

為什么有序集合需要同時使用跳躍表和字典來實現?

? ? ? ? 在理論上,有序集合可以單獨使用字典或者跳躍表來實現。但是,無論是單獨使用跳躍表還是字典,在性能上會比同時使用字典和跳躍表有所降低。

? ? ? ? 如果只使用字典來實現有序集合,雖然可以在O(1)時間復雜度內找到對應成員的分值。但是,因為字典是無序的方式來保存元素。所以在內存執行范圍型操作——比如:zrank,zrange等命令時,需要先將字典中的元素按照分值進行排序,完成排序至少需要O(NlogN)時間復雜度,以及額外的O(N)內存空間來保存排序好的元素。

? ? ? ? 如果只使用跳躍表來實現有序集合,那么跳躍表執行范圍型操作的所有優點會保存下來,但是,根據成員查找分值的操作,會從O(1)的時間時間復雜度提高到O(logN)。

? ? ? ? 所以為了提高效率,有序集合同時使用了跳躍表和字典兩種數據結構了實現。

? ? ? ? 如果上面price鍵創建使用的時skiplist編碼的有序集合對象,那么這個有序結合對象和zset將會如下圖所示:

? ? ? ? 注意:下圖為了展示清楚,重復展示了各個成員和分值,但是實際中,字典和跳躍表會共享元素和分值。

二.編碼轉換

?????????當有序集合同時滿足下面兩個條件時,對象使用ziplist編碼,redis5.0之后使用listpack編碼。

  • 有序集合保存的元素個數小于128個。
  • 有序集合保存的所有元素成員的長度小于64字節。

當面兩個的上限值可以通過配置,zset-max-ziplist-entries選項和zset-max-ziplist-value選項來修改。

三. 有序集合命令的實現

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/211210.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/211210.shtml
英文地址,請注明出處:http://en.pswp.cn/news/211210.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

鴻蒙app獲取文本控件按鈕控件_修改控件名稱_按鈕觸發事件_提示信息顯示

鴻蒙app獲取文本控件按鈕控件_修改控件名稱_按鈕觸發事件_ 點擊啟動:提示信息顯示 package com.example.myapplication.slice;import com.example.myapplication.ResourceTable; import ohos.aafwk.ability.AbilitySlice; import ohos.aafwk.content.Intent; impor…

12.1電梯控制器——文檔記錄

《數字邏輯》實驗報告 實驗名稱 項目三 電梯控制器設計 一、實驗目的 設計一個多樓層的電梯控制器系統,并能在開發板上模擬電梯運行狀態。可以利用按鍵作為呼叫按鍵,數碼管顯示電梯運行時電梯所在樓層,led燈顯示樓層叫梯狀態。 二、實…

太良心了!微軟面向初學者,開源機器學習、數據科學、AI、LLM

大家好,推薦幾個質量上乘且完全免費的微軟開源課程,由粉絲小伙伴梳理,分享給大家。 文末可以加我們粉絲群 面向初學者的機器學習課程 ML for beginners banner 地址:https://microsoft.github.io/ML-For-Beginners/#/ 學習經典…

[Linux] Web基礎知識與http協議

一、HTML 1.1 HTML 的概念 HTML被稱為超文本標記語言。 它是規范和標準. 它通過標記符號來標記網頁中出現的各個部分。網頁文件本身就是一種文本文件。 通過向文本文件添加標記,您可以告訴瀏覽器如何顯示其中的內容。 HTML命令可以描述文本、圖形、動畫、聲音、表格…

講解把一個文件夾里面的內容復制到另一個文件夾中的操作

🎊專欄【Java小練習】 🍔喜歡的詩句:天行健,君子以自強不息。 🎆音樂分享【如愿】 🎄歡迎并且感謝大家指出小吉的問題🥰 文章目錄 🍔需求?思路?代碼?效果 🎄如果要復制…

Vue3:表格單元格內容由:圖標+具體內容 構成

一、背景 在Vue3項目中,想讓單元格的內容是由 :圖標具體內容組成的,類似以下效果: 二、圖標 Element-Plus 可以在Element-Plus里面找是否有符合需求的圖標iconfont 如果Element-Plus里面沒有符合需求的,也可以在這…

MySQL 數據庫操作指南:LIMIT,OFFSET 和 JOIN 的使用

限制結果 您可以通過使用"LIMIT"語句來限制查詢返回的記錄數量。以下是一個示例,獲取您自己的Python服務器中"customers"表中的前5條記錄: import mysql.connectormydb mysql.connector.connect(host"localhost",user&…

Proteus仿真--基于NM24C08的EEPROM仿真設計

本文介紹基于NM24C08的EEPROM仿真設計(完整仿真源文件及代碼見文末鏈接) 其中NM24C08是標準的2線總線接口的串行EEPROM,開機畫面在LCD12864上顯示 仿真圖如下 仿真運行視頻 Proteus仿真--基于NM24C08的EEPROM仿真設計 附完整Proteus仿真資料…

零一萬物模型折騰筆記:官方 Yi-34B 模型基礎使用

當爭議和流量都消失后,或許現在是個合適的時間點,來拋開情緒、客觀的聊聊這個 34B 模型本身,尤其是實踐應用相關的一些細節。來近距離看看這個模型在各種實際使用場景中的真實表現和對硬件的性能要求。 或許,這會對也想在本地私有…

Docker本地部署Drupal內容管理框架并實現公網遠程訪問

文章目錄 前言1. Docker安裝Drupal2. 本地局域網訪問3 . Linux 安裝cpolar4. 配置Drupal公網訪問地址5. 公網遠程訪問Drupal6. 固定Drupal 公網地址7. 結語 前言 Dupal是一個強大的CMS,適用于各種不同的網站項目,從小型個人博客到大型企業級門戶網站。它…

bat腳本之findstr

findstr 是 Windows 操作系統中用于文本搜索的命令,它可以在文件中查找指定的字符串或正則表達式,并輸出匹配的行或行號。findstr 命令可以在命令提示符下直接使用,也可以在批處理腳本中嵌套使用。 以下是 findstr 命令的基本語法&#xff1…

使用條件格式突出顯示單元格數據-sdk

使用條件格式突出顯示單元格數據 2023 年 12 月 6 日 根據數據值將視覺提示應用于特定單元格、行或列,從而更輕松地識別模式和趨勢。 網格中的條件格式允許用戶根據單元格或范圍包含的數據將視覺樣式應用于單元格或范圍。它通過以數據驅動的方式突出顯示關鍵值、異常…

【基于Python的二手車數據可視化平臺的設計與實現】

基于Python的二手車數據可視化平臺的設計與實現 前言數據獲取與處理網絡爬蟲數據存儲 可視化平臺的設計與實現Flask框架數據可視化 創新點結語 前言 隨著社會的不斷發展,二手車市場也逐漸成為一個備受關注的領域。為了更好地為二手車的買家和賣家提供信息&#xff…

Python 實現全連接攻擊-1

實現或討論如何實現網絡攻擊,包括全連接攻擊(一種形式的拒絕服務攻擊),是不合適的,也違反了倫理和法律規定。無論是學術研究、安全測試還是其他目的,未經授權對網絡或系統進行攻擊都是非法和不道德的。 如…

計算和傳輸背后的時空觀

吞吐和速度(率)經常被混淆,當提到 100Gbps 網卡時,“它很快” 的意義可能只是 “它很多” 100Gbps 指 1s 內發送的比特數為 100G,如果在這 1s 內塞入更多比特,以下是兩種方式: 顯然,上面是更多&#xff…

安全防御–

安全防御 ASPF技術## FTP協議主機之間傳輸文件是IP網絡的一個重要功能,如今人們可以方便地使用網頁、郵箱進行文件傳輸。然而在互聯網早期,Web(World Wide Web,萬維網)還未出現,操作系統使用命令行的時代&a…

iOS分段控件UISegmentedControl使用

在故事板中添加UISegmentedControl 具體添加步聚如下: 選擇Xcode的View菜單下的Show Library (或者Shift+Common+L) 打開控件庫如下 在控件庫中輸入seg搜索控件,在出現Segmented Control后,將其拖到View Controller Scene中 到這里,添加分段控件UI已完成, 接下來將控件與變量…

shell的變量

Linux 系統中 shell 變量的使用 文章目錄 (1)簡介(2)變量分類(3)變量賦值(4)變量命名(5)變量引用(6)變量清除(7&#xff0…

基于JavaWeb+SSM+Vue馬拉松報名系統微信小程序的設計和實現

基于JavaWebSSMVue馬拉松報名系統微信小程序的設計和實現 源碼獲取入口Lun文目錄前言主要技術系統設計功能截圖訂閱經典源碼專欄Java項目精品實戰案例《500套》 源碼獲取 源碼獲取入口 Lun文目錄 1系統概述 1 1.1 研究背景 1 1.2研究目的 1 1.3系統設計思想 1 2相關技術 2 2.…

WPF仿網易云搭建筆記(0):項目搭建

文章目錄 前言項目地址項目Nuget包搭建項目初始化項目架構App.xaml引入MateralDesign資源包 項目初步分析將標題欄去掉DockPanel初步布局 資源字典舉例 結尾 前言 最近在找工作,發現沒有任何的WPF可以拿的出手的工作經驗,打算仿照網易云搭建一個WPF版本…