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

Redis?鍵值對(duì)(key-value)數(shù)據(jù)庫(kù)實(shí)現(xiàn)方法

 更新時(shí)間:2024年05月31日 14:38:20   作者:YoungSoulwt  
Redis 的鍵值對(duì)中的 key 就是字符串對(duì)象,而 value 可以是字符串對(duì)象,也可以是集合數(shù)據(jù)類型的對(duì)象,比如 List 對(duì)象,Hash 對(duì)象、Set 對(duì)象和 Zset 對(duì)象,這篇文章主要介紹了Redis?鍵值對(duì)數(shù)據(jù)庫(kù)是怎么實(shí)現(xiàn)的,需要的朋友可以參考下

在開始將數(shù)據(jù)結(jié)構(gòu)之前,先給介紹下 Redis 是怎樣實(shí)現(xiàn)鍵值對(duì)(key-value)數(shù)據(jù)庫(kù)的。

Redis 的鍵值對(duì)中的 key 就是字符串對(duì)象,而 value 可以是字符串對(duì)象,也可以是集合數(shù)據(jù)類型的對(duì)象,比如 List 對(duì)象,Hash 對(duì)象、Set 對(duì)象和 Zset 對(duì)象。

比如說:

> SET name "a"
OK
?
> HSET person name "a" age 18
?
>RPUSH stu "a" "b"
(integer) 4

這些命令代表著:

  • 第一條命令:name 是一個(gè)字符串鍵,因?yàn)殒I的值是一個(gè)字符串對(duì)象
  • 第二條命令:person 是一個(gè)哈希表鍵,因?yàn)殒I的值是一個(gè)包含兩個(gè)鍵值對(duì)的哈希表對(duì)象。
  • 第三條命令:stu 是一個(gè)列表鍵,因?yàn)殒I的值是一個(gè)包含兩個(gè)元素的列表對(duì)象。

這些鍵值對(duì)是如何保存在 Redis 中的呢?

Redis 是使用了一個(gè)【哈希表】保存所有鍵值對(duì),哈希表的最大好處就是讓我們可以用 O(1) 的時(shí)間復(fù)雜度來快速查找鍵值對(duì)。哈希表其實(shí)就是一個(gè)數(shù)組,數(shù)組中的元素叫做哈希桶。

Redis 的哈希桶是怎么保存鍵值對(duì)數(shù)據(jù)的呢?

哈希桶存放的是指向鍵值對(duì)數(shù)據(jù)的指針(dictEntry*),這樣通過指針就能找到鍵值對(duì)數(shù)據(jù),然后因?yàn)殒I值對(duì)的值可以保存字符串對(duì)象和集合數(shù)據(jù)類型的對(duì)象,所以鍵值對(duì)的數(shù)據(jù)結(jié)構(gòu)并不是直接保存值本身,而是保存了 void * key 和 void * value 指針,分別指向了實(shí)際的鍵對(duì)象和值對(duì)象,這樣一來,即使值是集合數(shù)據(jù),也可以通過 void * value 指針找到。

這里大概說下圖中涉及到的數(shù)據(jù)結(jié)構(gòu)的名字和用途:

  • redisDb 結(jié)構(gòu),表示 Redis 數(shù)據(jù)庫(kù)的結(jié)構(gòu),結(jié)構(gòu)體里存放了指向了 dict 結(jié)構(gòu)的指針;
  • dict 結(jié)構(gòu),結(jié)構(gòu)體里存放了 2 個(gè)哈希表,正常情況下都是用【哈希表1】,【哈希表2】只有在 rehash 的時(shí)候才用,具體什么是 rehash,會(huì)在哈希表數(shù)據(jù)結(jié)構(gòu)中說明;
  • dicttht 結(jié)構(gòu),表示哈希表的結(jié)構(gòu),結(jié)構(gòu)里存放了哈希表數(shù)組,數(shù)組中的每個(gè)元素都是指向一個(gè)哈希表節(jié)點(diǎn)結(jié)構(gòu)(dictEntry)的指針;
  • dictEntry 結(jié)構(gòu),表示哈希表節(jié)點(diǎn)的結(jié)構(gòu),結(jié)構(gòu)里存放了 void * key 和 void * value 指針,key 指向的是 String 對(duì)象,而 value 則可以指向 String 對(duì)象,也可以指向集合類型的對(duì)象,比如 List 對(duì)象、Hash 對(duì)象、Set 對(duì)象和 Zset 對(duì)象。

特別說明下,void * key 和 void * value 指針指向的是 Redis 對(duì)象,Redis 中的每個(gè)對(duì)象都由 redisObject 結(jié)構(gòu)表示,如下:

對(duì)象結(jié)構(gòu)里包含的成員變量:

  • type:標(biāo)識(shí)該對(duì)象是什么類型的對(duì)象(String 對(duì)象、List 對(duì)象、Hash 對(duì)象、Set 對(duì)象和 Zset 對(duì)象);
  • encoding:標(biāo)識(shí)該對(duì)象使用了哪種底層的數(shù)據(jù)結(jié)構(gòu);
  • ptr,指向底層數(shù)據(jù)結(jié)構(gòu)的指針。

Redis 對(duì)象和數(shù)據(jù)結(jié)構(gòu)的關(guān)系如下:

到此這篇關(guān)于Redis 鍵值對(duì)數(shù)據(jù)庫(kù)是怎么實(shí)現(xiàn)的的文章就介紹到這了,更多相關(guān)Redis 鍵值對(duì)數(shù)據(jù)庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論