Redis常見數(shù)據(jù)結(jié)構(gòu)以及使用場(chǎng)景分別是什么?
大家好,我是阿秀。
大家五一過的怎么樣啊?有沒有出去玩,哦不,有沒有被堵在路上...
機(jī)智的我選擇呆在實(shí)驗(yàn)室里看B站技術(shù)視頻和《計(jì)算機(jī)程序的構(gòu)造和解釋》。


五一結(jié)束之后再出去溜達(dá)溜達(dá),嘿嘿,完美避開游客高峰期。

阿秀五一期間除了瘋狂卷肝視頻之外也沒閑著,還把以前自己做的 Redis 筆記好好整理了一遍,大概整理出 25 道高頻面試題。由于篇幅原因,一次性更新 25 道題導(dǎo)致整體太過冗長(zhǎng),很多人可能根本看不過來(lái),所以 Redis 篇打算分為兩期更新。
另外,C++、操作系統(tǒng)、計(jì)算機(jī)網(wǎng)絡(luò)、MySQL 的硬核面試資料均已更新完畢,如果有還沒看過的可以先去看看啦。
《逆襲進(jìn)大廠系列》(包含C++、操作系統(tǒng)、計(jì)算機(jī)網(wǎng)絡(luò)、MySQL、Redis、情景題)
下面就把本期的 Redis 分享給大家吧。
1、聽說(shuō)過Redis嗎?它是什么?
Redis是一個(gè)數(shù)據(jù)庫(kù),不過與傳統(tǒng)數(shù)據(jù)庫(kù)不同的是Redis的數(shù)據(jù)庫(kù)是存在內(nèi)存中,所以讀寫速度非常快,因此 Redis被廣泛應(yīng)用于緩存方向。
除此之外,Redis也經(jīng)常用來(lái)做分布式鎖,Redis提供了多種數(shù)據(jù)類型來(lái)支持不同的業(yè)務(wù)場(chǎng)景。除此之外,Redis 支持事務(wù)持久化、LUA腳本、LRU驅(qū)動(dòng)事件、多種集群方案。
2、Redis的五種數(shù)據(jù)結(jié)構(gòu)整理簡(jiǎn)單動(dòng)態(tài)字符串(Simple Dynamic String,SDS)
Redis沒有直接使用C語(yǔ)言傳統(tǒng)的字符串,而是自己構(gòu)建了一種名為簡(jiǎn)單動(dòng)態(tài)字符串(Simple dynamic string,SDS)的抽象類型,并將SDS用作Redis的默認(rèn)字符串表示。
其實(shí)SDS等同于C語(yǔ)言中的char * ,但它可以存儲(chǔ)任意二進(jìn)制數(shù)據(jù),不能像C語(yǔ)言字符串那樣以字符’’來(lái)標(biāo)識(shí)字符串的結(jié) 束,因此它必然有個(gè)長(zhǎng)度字段。
定義struct sdshdr {
// 記錄buf數(shù)組中已使用字節(jié)的數(shù)量
// 等于sds所保存字符串的長(zhǎng)度
int len;
// 記錄buf數(shù)組中未使用字節(jié)的數(shù)量
int free;
// 字節(jié)數(shù)組,用于保存字符串
char buf[];
}
優(yōu)點(diǎn)獲取字符串長(zhǎng)度的復(fù)雜度為O(1)。杜絕緩沖區(qū)溢出。減少修改字符串長(zhǎng)度時(shí)所需要的內(nèi)存重分配次數(shù)。二進(jìn)制安全。兼容部分C字符串函數(shù)。
它具有很常規(guī)的 set/get 操作,value 可以是String也可以是數(shù)字,一般做一些復(fù)雜的計(jì)數(shù)功能的緩存。
鏈表
當(dāng)有一個(gè)列表鍵包含了數(shù)量比較多的元素,又或者列表中包含的元素都是比較長(zhǎng)的額字符串時(shí),Redis就會(huì)使用鏈表作為列表建的底層實(shí)現(xiàn)。
節(jié)點(diǎn)底層結(jié)構(gòu)typedef struct listNode {
// 前置節(jié)點(diǎn)
struct listNode *prev;
// 后置節(jié)點(diǎn)
struct listNode *next;
// 節(jié)點(diǎn)的值
void *value;
} listNode;
list底層結(jié)構(gòu)typedef struct list {
// 表頭節(jié)點(diǎn)
listNode *head;
// 表尾節(jié)點(diǎn)
listNode *tail;
// 鏈表所包含的節(jié)點(diǎn)數(shù)量
unsigned long len;
// 節(jié)點(diǎn)值復(fù)制函數(shù)
void *(*dup)(void *ptr);
// 節(jié)點(diǎn)值是放過函數(shù)
void (*free)(void *ptr);
// 節(jié)點(diǎn)值對(duì)比函數(shù)
int(*match)(void *ptr, void *key);
} list;
特性鏈表被廣泛用于實(shí)現(xiàn)Redis的各種功能,比如列表建、發(fā)布與訂閱、慢查詢、監(jiān)視器等。每個(gè)鏈表節(jié)點(diǎn)由一個(gè)listNode結(jié)構(gòu)來(lái)表示,每個(gè)節(jié)點(diǎn)都有一個(gè)指向前置節(jié)點(diǎn)和后置節(jié)點(diǎn)的指針,所以Redis的鏈表實(shí)現(xiàn)是雙端鏈表。每個(gè)鏈表使用一個(gè)list結(jié)構(gòu)表示,這個(gè)結(jié)構(gòu)帶有表頭節(jié)點(diǎn)指針、表尾節(jié)點(diǎn)指針,以及鏈表長(zhǎng)度等信息。因?yàn)殒湵肀眍^的前置節(jié)點(diǎn)和表尾節(jié)點(diǎn)的后置節(jié)點(diǎn)都指向NULL,所以Redis的鏈表實(shí)現(xiàn)是無(wú)環(huán)鏈表。通過為鏈表設(shè)置不同的類型特定函數(shù),Redis的鏈表可以用于保存各種不同類型的值。字典
字典的底層是哈希表,類似 C++中的 map ,也就是鍵值對(duì)。
發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
圖片新聞
-

落地?zé)o錫!京東首個(gè)物流機(jī)器人超級(jí)工廠來(lái)了
-

OpenAI發(fā)布的AI瀏覽器,市場(chǎng)為何反應(yīng)強(qiáng)烈?
-

馬云重返一線督戰(zhàn),阿里重啟創(chuàng)始人模式
-

機(jī)器人奧運(yùn)會(huì)戰(zhàn)報(bào):宇樹機(jī)器人摘下首金,天工Ultra搶走首位“百米飛人”
-

存儲(chǔ)圈掐架!江波龍起訴佰維,索賠121萬(wàn)
-

長(zhǎng)安汽車母公司突然更名:從“中國(guó)長(zhǎng)安”到“辰致科技”
-

豆包前負(fù)責(zé)人喬木出軌BP后續(xù):均被辭退
-

字節(jié)AI Lab負(fù)責(zé)人李航卸任后返聘,Seed進(jìn)入調(diào)整期
最新活動(dòng)更多
-
6月30日立即申請(qǐng)?jiān)囉?> 【免費(fèi)試用】旭之源工業(yè)電源一一機(jī)器人的穩(wěn)定“心臟“
-
精彩回顧立即查看>> 【限時(shí)免費(fèi)】物理場(chǎng)仿真助力生物醫(yī)學(xué)領(lǐng)域技術(shù)創(chuàng)新
-
精彩回顧立即查看>> 【直播】 智測(cè)未來(lái)·2026海克斯康春季產(chǎn)品創(chuàng)新日
-
精彩回顧立即查看>> 【線下論壇】新唐科技×芯唐南京 2026 年度研討會(huì)
-
精彩回顧立即查看>> OFweek 2026(第十五屆)中國(guó)機(jī)器人產(chǎn)業(yè)大會(huì)
-
精彩回顧立即查看>> 維科杯· OFweek 2025中國(guó)機(jī)器人行業(yè)年度評(píng)選
推薦專題
-
2 華為,重大突破!
- 1 人形機(jī)器人“第一股”來(lái)了!宇樹科技即將上會(huì)
- 2 全球股市陷AI獨(dú)大結(jié)構(gòu)性瘋狂
- 3 AI狂歡遇上油價(jià)破百,全球股市還能漲多久? | 產(chǎn)聯(lián)看全球
- 4 DeepSeek融資500億,梁文鋒難逃資本局
- 5 谷歌2026 I/O大會(huì)完整回顧:模型依然重要,但智能體正在接管一切
- 6 全球資本,重倉(cāng)中國(guó)機(jī)器人
- 7 Figure AI 交付突破350臺(tái),陪跑特斯拉會(huì)迎來(lái)iPhone 時(shí)刻嗎?
- 8 Anthropic發(fā)布2028年全球AI領(lǐng)導(dǎo)力的兩種情景報(bào)告
- 9 “國(guó)產(chǎn)GPU第一股”摩爾線程首季扭虧,但造血能力仍待考驗(yàn)
- 10 特斯拉宣布監(jiān)督版FSD登陸中國(guó)?
- 高級(jí)軟件工程師 廣東省/深圳市
- 自動(dòng)化高級(jí)工程師 廣東省/深圳市
- 光器件研發(fā)工程師 福建省/福州市
- 銷售總監(jiān)(光器件) 北京市/海淀區(qū)
- 激光器高級(jí)銷售經(jīng)理 上海市/虹口區(qū)
- 光器件物理工程師 北京市/海淀區(qū)
- 激光研發(fā)工程師 北京市/昌平區(qū)
- 技術(shù)專家 廣東省/江門市
- 封裝工程師 北京市/海淀區(qū)
- 結(jié)構(gòu)工程師 廣東省/深圳市


分享





