黄色国产视频,男女啪啪18禁无遮挡激烈,久草热8精品视频在线观看,四虎国产精品永久在线下载

            數據庫查找key在內存中的位置的方法

            時間:2022-06-24 20:31:25 數據庫操作系統 我要投稿
            • 相關推薦

            數據庫查找key在內存中的位置的方法

              一、預先需要了解的知識

              1、redis 中的每一個數據庫,都由一個 redisDb 的結構存儲。其中,redisDb.id 存儲著 redis 數據庫以整數表示的號碼。redisDb.dict 存儲著該庫所有的鍵值對數據。redisDb.expires 保存著每一個鍵的過期時間。

              2、當redis 服務器初始化時,會預先分配 16 個數據庫(該數量可以通過配置文件配置),所有數據庫保存到結構 redisServer 的一個成員 redisServer.db 數組中。當我們選擇數據庫 select number 時,程序直接通過 redisServer.db[number] 來切換數據庫。有時候當程序需要知道自己是在哪個數據庫時,直接讀取 redisDb.id 即可。

              3、既然我們知道一個數據庫的所有鍵值都存儲在redisDb.dict中,那么我們要知道如果找到key的位置,就有必要了解一下dict 的結構了:

              復制代碼 代碼如下:typedef struct dict {

              // 特定于類型的處理函數

              dictType *type;

              // 類型處理函數的私有數據

              void *privdata;

              // 哈希表(2個)

              dictht ht[2];

              // 記錄 rehash 進度的標志,值為-1 表示 rehash 未進行

              int rehashidx;

              // 當前正在運作的安全迭代器數量

              int iterators;

              } dict;

              由上述的結構可以看出,redis 的字典使用哈希表作為其底層實現。dict 類型使用的兩個指向哈希表的指針,其中 0 號哈希表(ht[0])主要用于存儲數據庫的所有鍵值,而1號哈希表主要用于程序對 0 號哈希表進行 rehash 時使用,rehash 一般是在添加新值時會觸發,這里不做過多的贅述。所以redis 中查找一個key,其實就是對進行該dict 結構中的 ht[0] 進行查找操作。

              4、既然是哈希,那么我們知道就會有哈希碰撞,那么當多個鍵哈希之后為同一個值怎么辦呢?redis采取鏈表的方式來存儲多個哈希碰撞的鍵。也就是說,當根據key的哈希值找到該列表后,如果列表的長度大于1,那么我們需要遍歷該鏈表來找到我們所查找的key。當然,一般情況下鏈表長度都為是1,所以時間復雜度可看作o(1)。

              二、當redis 拿到一個key 時,如果找到該key的位置。

              了解了上述知識之后,我們就可以來分析redis如果在內存找到一個key了。

              1、當拿到一個key后, redis 先判斷當前庫的0號哈希表是否為空,即:if (dict->ht[0].size == 0)。如果為true直接返回NULL。

              2、判斷該0號哈希表是否需要rehash,因為如果在進行rehash,那么兩個表中者有可能存儲該key。如果正在進行rehash,將調用一次_dictRehashStep方法,_dictRehashStep 用于對數據庫字典、以及哈希鍵的字典進行被動 rehash,這里不作贅述。

              3、計算哈希表,根據當前字典與key進行哈希值的計算。

              4、根據哈希值與當前字典計算哈希表的索引值。

              5、根據索引值在哈希表中取出鏈表,遍歷該鏈表找到key的位置。一般情況,該鏈表長度為1。

              6、當 ht[0] 查找完了之后,再進行了次rehash判斷,如果未在rehashing,則直接結束,否則對ht[1]重復345步驟。

              到此我們就找到了key在內存的中位置了。

              

            主站蜘蛛池模板: 亚洲国产人在线播放首页| 国产高清视频在线免费观看| 亚洲视频男人的天堂| 又黄又硬又湿又刺激视频免费 | 国产区图片区一区二区三区| 又大又长又粗又硬又爽少妇毛片 | 激情亚洲网| 一级三级毛片| 毛片在线看看| 久久久久国产精品人妻电影 | 国产乱人伦av在线a| 国产精品免费看久久久| 九九夜| 一级特黄免费| 成年人福利网站| 熟女人妻大叫粗大受不了| 国产农村妇女毛片精品久久| 美女免费av| 国产精品图片| 国产猛男猛女超爽免费视频| 亚洲精品精华液一区二区| 天天做天天爱夜夜爽毛片毛片| 欧美理论影院| 欧美色综合色| 99精品国产一区二区电影| 国产午夜福利亚洲第一| www.黄在线| 日本一级爽快片野花| 日韩一区久久| 无码专区 人妻系列 在线| 无码av一区二区三区不卡| 91精品国产9999久久久| 欧美视频在线观看一区| 黄色片网站在线看| 亚欧AV无码乱码在线观看性色| 国产基佬gv在线观看网站| 3d动漫精品一区二区三区免费| 欧美日韩在线不卡| 国产永久毛片| 特级毛片在线大全免费播放| 亚洲一区二区三区高清在线看|