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

redis數(shù)據(jù)庫(kù)查找key在內(nèi)存中的位置的方法

 更新時(shí)間:2014年03月20日 09:50:42   作者:  
這篇文章主要介紹了redis數(shù)據(jù)庫(kù)查找key在內(nèi)存中的位置的方法,需要的朋友可以參考下

一、預(yù)先需要了解的知識(shí)
1、redis 中的每一個(gè)數(shù)據(jù)庫(kù),都由一個(gè) redisDb 的結(jié)構(gòu)存儲(chǔ)。其中,redisDb.id 存儲(chǔ)著 redis 數(shù)據(jù)庫(kù)以整數(shù)表示的號(hào)碼。redisDb.dict 存儲(chǔ)著該庫(kù)所有的鍵值對(duì)數(shù)據(jù)。redisDb.expires 保存著每一個(gè)鍵的過期時(shí)間。
2、當(dāng)redis 服務(wù)器初始化時(shí),會(huì)預(yù)先分配 16 個(gè)數(shù)據(jù)庫(kù)(該數(shù)量可以通過配置文件配置),所有數(shù)據(jù)庫(kù)保存到結(jié)構(gòu) redisServer 的一個(gè)成員 redisServer.db 數(shù)組中。當(dāng)我們選擇數(shù)據(jù)庫(kù) select number  時(shí),程序直接通過 redisServer.db[number] 來切換數(shù)據(jù)庫(kù)。有時(shí)候當(dāng)程序需要知道自己是在哪個(gè)數(shù)據(jù)庫(kù)時(shí),直接讀取 redisDb.id 即可。
3、既然我們知道一個(gè)數(shù)據(jù)庫(kù)的所有鍵值都存儲(chǔ)在redisDb.dict中,那么我們要知道如果找到key的位置,就有必要了解一下dict 的結(jié)構(gòu)了:

復(fù)制代碼 代碼如下:
typedef struct dict {

// 特定于類型的處理函數(shù)
dictType *type;

// 類型處理函數(shù)的私有數(shù)據(jù)
void *privdata;

// 哈希表(2個(gè))
dictht ht[2];

// 記錄 rehash 進(jìn)度的標(biāo)志,值為-1 表示 rehash 未進(jìn)行
int rehashidx;

// 當(dāng)前正在運(yùn)作的安全迭代器數(shù)量
int iterators;
} dict;


由上述的結(jié)構(gòu)可以看出,redis 的字典使用哈希表作為其底層實(shí)現(xiàn)。dict 類型使用的兩個(gè)指向哈希表的指針,其中 0 號(hào)哈希表(ht[0])主要用于存儲(chǔ)數(shù)據(jù)庫(kù)的所有鍵值,而1號(hào)哈希表主要用于程序?qū)?0 號(hào)哈希表進(jìn)行 rehash 時(shí)使用,rehash 一般是在添加新值時(shí)會(huì)觸發(fā),這里不做過多的贅述。所以redis 中查找一個(gè)key,其實(shí)就是對(duì)進(jìn)行該dict 結(jié)構(gòu)中的 ht[0] 進(jìn)行查找操作。
4、既然是哈希,那么我們知道就會(huì)有哈希碰撞,那么當(dāng)多個(gè)鍵哈希之后為同一個(gè)值怎么辦呢?redis采取鏈表的方式來存儲(chǔ)多個(gè)哈希碰撞的鍵。也就是說,當(dāng)根據(jù)key的哈希值找到該列表后,如果列表的長(zhǎng)度大于1,那么我們需要遍歷該鏈表來找到我們所查找的key。當(dāng)然,一般情況下鏈表長(zhǎng)度都為是1,所以時(shí)間復(fù)雜度可看作o(1)。
二、當(dāng)redis 拿到一個(gè)key 時(shí),如果找到該key的位置。
了解了上述知識(shí)之后,我們就可以來分析redis如果在內(nèi)存找到一個(gè)key了。
1、當(dāng)拿到一個(gè)key后, redis 先判斷當(dāng)前庫(kù)的0號(hào)哈希表是否為空,即:if (dict->ht[0].size == 0)。如果為true直接返回NULL。
2、判斷該0號(hào)哈希表是否需要rehash,因?yàn)槿绻谶M(jìn)行rehash,那么兩個(gè)表中者有可能存儲(chǔ)該key。如果正在進(jìn)行rehash,將調(diào)用一次_dictRehashStep方法,_dictRehashStep 用于對(duì)數(shù)據(jù)庫(kù)字典、以及哈希鍵的字典進(jìn)行被動(dòng) rehash,這里不作贅述。
3、計(jì)算哈希表,根據(jù)當(dāng)前字典與key進(jìn)行哈希值的計(jì)算。
4、根據(jù)哈希值與當(dāng)前字典計(jì)算哈希表的索引值。
5、根據(jù)索引值在哈希表中取出鏈表,遍歷該鏈表找到key的位置。一般情況,該鏈表長(zhǎng)度為1。
6、當(dāng) ht[0] 查找完了之后,再進(jìn)行了次rehash判斷,如果未在rehashing,則直接結(jié)束,否則對(duì)ht[1]重復(fù)345步驟。
到此我們就找到了key在內(nèi)存的中位置了。

相關(guān)文章

  • SQL中Having與Where的區(qū)別及注意

    SQL中Having與Where的區(qū)別及注意

    這篇文章給大家詳細(xì)的介紹了SQL中Having與Where的區(qū)別,以及這兩者的注意事項(xiàng),文中還分享了Having與Where的示例代碼,相信對(duì)大家的理解和學(xué)習(xí)很有幫助,感興趣的朋友們可以參考借鑒,有需要的朋友們可以一起學(xué)習(xí)學(xué)習(xí)。
    2016-11-11
  • Navicat?premium?for?mac?12的安裝破解圖文教程

    Navicat?premium?for?mac?12的安裝破解圖文教程

    Navicat Premium是一款數(shù)據(jù)庫(kù)管理工具,將此工具連接數(shù)據(jù)庫(kù),你可以從中看到各種數(shù)據(jù)庫(kù)的詳細(xì)信息,這篇文章主要介紹了Mac下Navicat?premium?for?mac?12的安裝破解過程,需要的朋友可以參考下
    2024-01-01
  • 將sqlite3中數(shù)據(jù)導(dǎo)入到mysql中的實(shí)戰(zhàn)教程

    將sqlite3中數(shù)據(jù)導(dǎo)入到mysql中的實(shí)戰(zhàn)教程

    最近因?yàn)楣ぷ鞯男枨?,需要將sqlite3中的數(shù)據(jù)導(dǎo)入到mysql中去,發(fā)現(xiàn)網(wǎng)上的一些教程都不夠詳細(xì),索性自己寫一篇,下面這篇文章主要給大家介紹了關(guān)于將sqlite3數(shù)據(jù)庫(kù)中的數(shù)據(jù)導(dǎo)入到mysql數(shù)據(jù)庫(kù)中的相關(guān)資料,需要的朋友可以參考下。
    2017-07-07
  • navicat怎么卸載,navicat徹底卸載干凈教程

    navicat怎么卸載,navicat徹底卸載干凈教程

    這篇文章主要介紹了navicat怎么卸載?navicat徹底卸載干凈教程。具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 數(shù)據(jù)庫(kù)修改多對(duì)多的中間表的記錄的技巧

    數(shù)據(jù)庫(kù)修改多對(duì)多的中間表的記錄的技巧

    修改多對(duì)多的中間表的記錄的方法,需要的朋友可以參考下。提高效率。
    2010-01-01
  • 數(shù)據(jù)庫(kù)librarydb多表查詢的操作方法

    數(shù)據(jù)庫(kù)librarydb多表查詢的操作方法

    這篇文章主要介紹了數(shù)據(jù)庫(kù)librarydb多表查詢的操作方法,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-12-12
  • mssql注入躲避IDS的方法

    mssql注入躲避IDS的方法

    可能這個(gè)技巧早有人已經(jīng)會(huì)了,就是利用openrowset發(fā)送本地命令。通常我們的用法是(包括MSDN的列子)
    2008-06-06
  • 深入SQL中PIVOT 行列轉(zhuǎn)換詳解

    深入SQL中PIVOT 行列轉(zhuǎn)換詳解

    T-SQL語(yǔ)句中,Pivot運(yùn)算符用于在列和行之間對(duì)數(shù)據(jù)進(jìn)行旋轉(zhuǎn)或透視轉(zhuǎn)換,PIVOT命令可以實(shí)現(xiàn)數(shù)據(jù)表的列轉(zhuǎn)行,同時(shí)執(zhí)行聚合運(yùn)算,UNPIVOT則與其相反,實(shí)現(xiàn)數(shù)據(jù)的行轉(zhuǎn)列。
    2015-10-10
  • MDAC2.8 安裝問題與解決方法

    MDAC2.8 安裝問題與解決方法

    根據(jù)Windows XP的版本不同,有的版本需要安裝MDAC2.8,一般Windows XP SP2或以上版本就不需要安裝。不需要安裝時(shí)系統(tǒng)會(huì)提示“MDAC 2.8 RTM 與此版本 Windows 不兼容。現(xiàn)在它的所有功能都成為 Windows 的一部分”。
    2010-11-11
  • Ubuntu 17.10安裝phpMyAdmin數(shù)據(jù)庫(kù)管理工具配置詳解

    Ubuntu 17.10安裝phpMyAdmin數(shù)據(jù)庫(kù)管理工具配置詳解

    這篇文章主要介紹了Ubuntu 17.10安裝phpMyAdmin數(shù)據(jù)庫(kù)管理工具,通過示例代碼給大家講解了安裝phpmyadmin數(shù)據(jù)庫(kù)的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-03-03

最新評(píng)論