亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Redis動態(tài)字符串SDS的實現(xiàn)

 更新時間:2023年11月20日 08:45:33   作者:中二Espresso  
SDS在Redis中是實現(xiàn)字符串對象的工具,本文主要介紹了Redis動態(tài)字符串SDS的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下

動態(tài)字符串SDS

Redis中保存的Key是字符串,value往往是字符串或者字符串的集合??梢娮址荝edis中最常用的一種數(shù)據(jù)結(jié)構(gòu)。

不過Redis沒有直接使用C語言中的字符串,因為C語言字符串存在很多問題:

  • 獲取字符串長度的需要通過運算
  • 非二進制安全
  • 非二進制安全

Redis構(gòu)建了一種新的字符串結(jié)構(gòu),稱為簡單動態(tài)字符串Simple Dynamic String),簡稱SDS。

例如,我們執(zhí)行命令:

set name dcy

那么Redis將在底層創(chuàng)建兩個SDS,其中一個是包含“name”的SDS,另一個是包含“dcy”的SDS

Redis是C語言實現(xiàn)的,其中SDS是一個結(jié)構(gòu)體(類似Java的類),源碼如下:

struct __attribute__ ((__packed__)) sdshdr8 {
    uint8_t len; /* buf已保存的字符串字節(jié)數(shù),不包含結(jié)束標示*/
    uint8_t alloc; /* buf申請的總的字節(jié)數(shù),不包含結(jié)束標示*/
    unsigned char flags; /* 不同SDS的頭類型,用來控制SDS的頭大小
    char buf[];
};

不同SDS的頭類型

#define SDS_TYPE_5  0
#define SDS_TYPE_8  1
#define SDS_TYPE_16 2
#define SDS_TYPE_32 3
#define SDS_TYPE_64 4

例如,一個包含字符串“name”的sds結(jié)構(gòu)如下:

SDS之所以叫做動態(tài)字符串,是因為它具備動態(tài)擴容的能力,例如一個內(nèi)容為“hi”的SDS:

假如我們要給SDS追加一段字符串 “,Amy” ,這里首先會申請新內(nèi)存空間:

  • 如果新字符串小于1M,則新空間為擴展后字符串長度的兩倍+1
  • 如果新字符串大于1M,則新空間為擴展后字符串長度+1M+1。稱為內(nèi)存預(yù)分配。

優(yōu)點:

  • 獲取字符串長度的時間復雜度為O(1)
  • 支持動態(tài)擴容
  • 減少內(nèi)存分配次數(shù)
  • 二進制安全

到此這篇關(guān)于Redis動態(tài)字符串SDS的實現(xiàn)的文章就介紹到這了,更多相關(guān)Redis動態(tài)字符串SDS內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Redis未授權(quán)訪問配合SSH key文件利用詳解

    Redis未授權(quán)訪問配合SSH key文件利用詳解

    這篇文章主要給大家介紹了關(guān)于Redis未授權(quán)訪問配合SSH key文件利用的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-09-09
  • Redis 哨兵集群的實現(xiàn)

    Redis 哨兵集群的實現(xiàn)

    Sentinel是Redis 的高可用性解決方案,本文詳細的介紹了redis哨兵集群的實現(xiàn),非常具有實用價值,需要的朋友可以參考下
    2021-06-06
  • Redis+Hbase+RocketMQ?實際使用問題案例講解

    Redis+Hbase+RocketMQ?實際使用問題案例講解

    這篇文章主要介紹了Redis+Hbase+RocketMQ?實際使用問題案例分享,本文結(jié)合示例代碼給大家講解的非常詳細,需要的朋友可以參考下
    2023-01-01
  • Redis與數(shù)據(jù)庫數(shù)據(jù)一致性的原因及解決方案

    Redis與數(shù)據(jù)庫數(shù)據(jù)一致性的原因及解決方案

    Redis作為一種高效的鍵值對存儲系統(tǒng),常用于緩存數(shù)據(jù)庫減少IO操作,下面這篇文章主要介紹了Redis與數(shù)據(jù)庫數(shù)據(jù)一致性的原因及解決方案,文中介紹的非常詳細,需要的朋友可以參考下
    2025-04-04
  • 使用redis實現(xiàn)延遲通知功能(Redis過期鍵通知)

    使用redis實現(xiàn)延遲通知功能(Redis過期鍵通知)

    這篇文章主要介紹了使用redis實現(xiàn)延遲通知功能(Redis過期鍵通知)的相關(guān)知識,本文通過實例代碼圖文相結(jié)合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2021-09-09
  • 幾分鐘教你掌握Redis簡單動態(tài)字符串SDS

    幾分鐘教你掌握Redis簡單動態(tài)字符串SDS

    這篇文章主要為大家介紹了幾分鐘教你掌握Redis簡單動態(tài)字符串SDS方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • 本地訪問不到公網(wǎng)redis的解決方案

    本地訪問不到公網(wǎng)redis的解決方案

    本文詳述了本地訪問不到公網(wǎng)redis的解決方案,包括分析報錯原因、Redis配置文件的區(qū)別、bind和protected-mode配置的解析,最終通過修改Redis配置文件及創(chuàng)建啟動腳本解決了訪問不到公網(wǎng)redis得問題,需要的朋友可以參考下
    2024-08-08
  • Redis內(nèi)存碎片率調(diào)優(yōu)處理方式

    Redis內(nèi)存碎片率調(diào)優(yōu)處理方式

    Redis集群因內(nèi)存碎片率超過1.5觸發(fā)告警,分析發(fā)現(xiàn)內(nèi)因與外因?qū)е聝?nèi)存碎片,內(nèi)因為操作系統(tǒng)內(nèi)存分配機制,外因為Redis操作特性,使用Redis內(nèi)置內(nèi)存碎片清理機制可有效降低碎片率,但需注意可能影響性能,建議使用MEMORY命令診斷內(nèi)存使用情況,合理配置參數(shù)以優(yōu)化性能
    2024-09-09
  • Redis模擬延時隊列實現(xiàn)日程提醒的方法

    Redis模擬延時隊列實現(xiàn)日程提醒的方法

    文章介紹了如何使用Redis實現(xiàn)一個簡單的延時任務(wù)隊列,通過Redis的有序集合特性來存儲和管理延時任務(wù),通過定期檢查集合中小于等于當前時間的任務(wù)并執(zhí)行,可以實現(xiàn)延時任務(wù)的管理,感興趣的朋友跟隨小編一起看看吧
    2024-11-11
  • redis防止短信惡意調(diào)用的實現(xiàn)

    redis防止短信惡意調(diào)用的實現(xiàn)

    本文主要介紹了在場景登錄或注冊接口中使用短信驗證碼時遇到的惡意調(diào)用問題,并通過使用Redis分布式鎖來解決,具有一定的參考價值,感興趣的可以了解一下
    2025-02-02

最新評論