婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Redis數(shù)據(jù)結(jié)構(gòu)之鏈表與字典的使用

Redis數(shù)據(jù)結(jié)構(gòu)之鏈表與字典的使用

熱門標簽:日本中國地圖標注 山東外呼銷售系統(tǒng)招商 鄭州人工智能電銷機器人系統(tǒng) 北京400電話辦理收費標準 魔獸2青云地圖標注 超呼電話機器人 貴州電銷卡外呼系統(tǒng) 宿遷便宜外呼系統(tǒng)平臺 十堰營銷電銷機器人哪家便宜

今天我們來聊一聊Redis中的鏈表與字典,具體如下:

鏈表

關于鏈表的基礎概念其實你在學習Redis之前一定積累了不少,所以本文將默認你已經(jīng)掌握了鏈表相關的基礎知識,而Redis的鏈表其實也就是普通的鏈表~

因為Redis是使用C語言編寫的,因此Redis的數(shù)據(jù)結(jié)構(gòu)的定義都是使用C語法定義的,你不需要完全理解下方C語言聲明結(jié)構(gòu)體的語法,但我認為依靠大家的Java知識也能理解這就像是在Java中定義了一個鏈表對象

Redis鏈表節(jié)點的結(jié)構(gòu)

typedef struct listNode {
	struct listNode *prev;	//指向前一個鏈表節(jié)點
	struct listNode *next;	//指向后一個鏈表節(jié)點
	void *value;			//當前節(jié)點的值(可以按需設定不同數(shù)據(jù)類型的value)
} listNode;

很明顯,當每一個節(jié)點內(nèi)記錄了前后兩個節(jié)點位置之后,鏈表節(jié)點之間就能夠彼此前后相連,組成雙向通行車道(可以雙向遍歷)

Redis鏈表的表示

上面講解了Redis的鏈表的節(jié)點表示,并由此引申了一下可以借此構(gòu)建Redis雙端鏈表,而事實上,對于每一個存在的雙端鏈表,Redis使用一個list結(jié)構(gòu)來表示

typedef struct list {
	listNode *head;			//表頭節(jié)點
	listNode *tail;			//表尾節(jié)點
	unsigned long len;		//鏈表所包含的節(jié)點的數(shù)量
	void *(*dup)(void *ptr);	//節(jié)點復制函數(shù)
	void (*free)(void *ptr);	//節(jié)點釋放函數(shù)
	void (*match)(void *ptr, void *key);//節(jié)點值對比函數(shù)
} list;

很明顯,你看到三個好像是返回值為void的函數(shù),但是看不懂C語法,沒關系,傳統(tǒng)后端功夫,自然是點到為止

Redis鏈表用在哪

我不想現(xiàn)在就告訴你,鏈表被廣泛用于實現(xiàn)Redis的各種功能,比如列表鍵、發(fā)布于訂閱、慢查詢、監(jiān)視器等,等我們后面講到這幾部分的時候,白澤再結(jié)合鏈表和你細說~

字典

和鏈表一樣,Redis所使用的C語言并沒有內(nèi)置字典這種數(shù)據(jù)結(jié)構(gòu),因此Redis構(gòu)建了自己的字典實現(xiàn)。如果你學過數(shù)據(jù)結(jié)構(gòu),你會發(fā)現(xiàn)Redis的字典事實上就是數(shù)據(jù)結(jié)構(gòu)中的鄰接表,即使沒學過,往下看就好啦~

Redis字典結(jié)構(gòu)總覽

數(shù)組 + 鏈表 ==> 鄰接表,實錘

Redis字典結(jié)構(gòu)分解

還記得嗎,上面我們說Redis鏈表可以用list描述,但是鏈表存儲的數(shù)據(jù)本質(zhì)上,是由一系列l(wèi)istNode節(jié)點通過前后指針相連存儲的;類似的,Redis字典可以用如下dict描述,但是字典存儲的數(shù)據(jù)本質(zhì)上,是由數(shù)組 + 若干鏈表組合得到的數(shù)據(jù)結(jié)構(gòu)存儲的,字典dict結(jié)構(gòu)如下:

typedef struct dict {
	dictType *type;			//類型特定函數(shù)
	void *privdata;			//私有數(shù)據(jù)
	dictht ht[2];			//哈希表數(shù)組
	int trehashidx;			//rehash索引,當rehash不在進行時,值為-1
} dict;

現(xiàn)在你只需要關注其中的哈希表數(shù)組ht[2],它的數(shù)據(jù)類型為dictht,因此也是一種復合的數(shù)據(jù)結(jié)構(gòu),如下:

typedef struct dictht {
	dictEntry **table;		//哈希表數(shù)組
	unsigned long size;		//哈希表大小
	unsigned long sizemax;	//哈希表大小掩碼,用于計算索引值,等于size - 1
	unsigned long used;		//該哈希表已有節(jié)點的數(shù)量
} dictht;

哈希表dictht是Redis字典的核心,dictht的四個屬性中,size、sizemax、used都是用于描述table屬性整體狀態(tài)。看到這你就明白了,dictht的核心是dictEntry類型的table屬性(再次提醒,如果沒有C語言的基礎,本文中一切你看不懂的語法,包括數(shù)據(jù)類型,你只需要一眼帶過即可,我們的目的是學習Redis的設計思想)

table屬性是一個數(shù)組,數(shù)組中的每個元素都是一個指向dictEntry結(jié)構(gòu)的指針,每個dictEntry結(jié)構(gòu)保存一個鍵值對,并含有一個指向下一個dictEntry的指針,結(jié)構(gòu)如下:

typedef struct dictEntry {
	void *key;	//鍵
	union {		//值(可以是一個指針,可以是一個uint64_t類型的整數(shù),也可以是一個int64_t類型的整數(shù))
		void *val;
		uint64_t u64;
		int64_t s64;
	} v;
	struct dictEntry *next;//指向下個哈希表節(jié)點,形成鏈表
} dictEntry;

哈希算法

我們知道,字典是用來存儲數(shù)據(jù)的,并且是以鍵值對的形式存儲的,那么我每次存入一個鍵值對放在字典的哪里?這就是哈希算法為你解決的事情:程序需要先根據(jù)鍵值對的鍵計算出哈希值和索引值,然后再根據(jù)索引值,將包含新鍵值對的哈希表節(jié)點放到哈希表數(shù)組的指定索引上面

比如我已經(jīng)有下面這個字典,然后要插入一個鍵值對數(shù)據(jù):k1 : v1,則程序有如下計算過程:(用戶只是往Redis服務器中插入了一條數(shù)據(jù),下面都是程序內(nèi)部的工作~)

hash = dict->type->hashFunction(k1);		//計算k1鍵的hash值(得到某個數(shù)值)
index = hash  dict->ht[0].sizemask = 1;	//計算k1鍵插入位置的索引值

解決鍵沖突

鍵沖突:當不同的key值計算得到的dictEntry索引值相同時,就稱發(fā)生鍵沖突(我要插入的位置已經(jīng)被占用了,插入使得鏈表長度由1變多,當然第一次插入不算沖突)

解決方法:

就像上面我要插入一個k1 :v1的鍵值對,并計算得到插入位置的索引為1(但是distEntry數(shù)組中索引為1的位置已經(jīng)有k0 :v0鍵值對存放了),因此程序會在哈希表ht[0]的dictEntry數(shù)組的索引為1的位置上插入一個dictEntry節(jié)點,放在原本鏈表首部的前一位置(搶占首位),其中存放著k1 : v1鍵值對,插入后的圖如下:

你可能疑惑新插入的鍵值對的位置在每個dictEntry鏈表的最前面,而不是尾部,原因是每個dictEntry中除了保存鍵值對之外,只記錄了下一個dictEntry的地址(上面我已經(jīng)給出了dictEntry的結(jié)構(gòu)了~),程序無法直接得到dictEntry鏈表的最后一個節(jié)點,但可以直接得到第一個節(jié)點(通過dictEntry數(shù)組索引直接定位),因此每次插入的dictEntry節(jié)點(鍵值對)都將直接插入到對應索引的鏈表的頭部(因此dictEntry數(shù)組的內(nèi)容是不斷在變的)

一句話來說:distEntry數(shù)組幫助使用索引定位,distEntry鏈表,用于處理沖突,不斷維護所存儲的鍵值對數(shù)據(jù)

rehash

隨著操作的不斷執(zhí)行(增、刪、改、查),哈希表保存的鍵值對會逐漸增多或者減少,為了讓哈希表的負載因子維持在一個合理范圍內(nèi),當哈希表保存的鍵值對數(shù)量太多或太少時,程序會對哈希表的大小進行相應的擴展或者收縮(不知道你是否記得還有一個哈希表ht[1]的存在,這個表就是為了和ht[0]配合進行rehash而存在的)

rehash步驟:

為字典的ht[1]哈希表分配空間

如果程序執(zhí)行擴展操作:

ht[1].size = 第一個大于等于ht[0].used * 2(ht[0]已經(jīng)使用的空間大小乘2)的2的n次方冪

如果程序執(zhí)行收縮操作:

ht[1].size = 第一個大于等于ht[0].used(ht[0]已經(jīng)使用的空間大小)的2的n次方冪

將保存在ht[0]上的鍵值對rehash到ht[1]上,因為size不同,所以是重新hash,而不是整體復制

當ht[0]內(nèi)鍵值對全部遷移到ht[1]中后,釋放ht[0],然后將ht[1]和ht[0]的互換(rehash結(jié)束),此時ht[0]就是一個rehash后的哈希表,而ht[1]依舊為空表,為下次rehash做準備

漸進式rehash

上面提到的在哈希表ht[0]的負載因子過大或者過小會觸發(fā)rehash,但是,事實上rehash遷移的過程不是一蹴而就的(很明顯,如果數(shù)據(jù)ht[0]的數(shù)據(jù)很多,每次rehash如果都遷移全部數(shù)據(jù),需要花費較大時間等待,用戶在rehash期間訪問Redis服務器將會陷入無響應的狀態(tài))

漸進式過程:

將rehash的過程分攤在后續(xù)的每次增、刪、改、查操作上,在rehash期間,每次對字典執(zhí)行操作,程序除了執(zhí)行指定操作外,還會順帶將ht[0]哈希表在rehashidx索引(從0開始,-1表示rehash未開始)上的所有鍵值對rehash到ht[1],當每次局部rehash工作完成后,程序?qū)ehashidx屬性的值增一

注意:每次對字典進行增、刪、改、查會在ht[0]和ht[1]上同時進行,比如查找一個鍵,則會現(xiàn)在ht[0]上查找,沒找到再去ht[1]上查找,諸如此類,除了增加操作每次都將直接hash到ht[1]上,不會對ht[0]執(zhí)行任何添加操作

到此這篇關于Redis數(shù)據(jù)結(jié)構(gòu)之鏈表與字典的使用的文章就介紹到這了,更多相關Redis 鏈表與字典內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Redis快速表、壓縮表和雙向鏈表(重點介紹quicklist)
  • Redis數(shù)組和鏈表深入詳解
  • redis源碼分析教程之壓縮鏈表ziplist詳解
  • 詳解Redis中的雙鏈表結(jié)構(gòu)

標簽:果洛 北京 臺州 江蘇 吉安 大慶 朝陽 楊凌

巨人網(wǎng)絡通訊聲明:本文標題《Redis數(shù)據(jù)結(jié)構(gòu)之鏈表與字典的使用》,本文關鍵詞  Redis,數(shù)據(jù)結(jié)構(gòu),之鏈,表,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關。
  • 相關文章
  • 下面列出與本文章《Redis數(shù)據(jù)結(jié)構(gòu)之鏈表與字典的使用》相關的同類信息!
  • 本頁收集關于Redis數(shù)據(jù)結(jié)構(gòu)之鏈表與字典的使用的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲一区二区成人在线观看| 国产a久久麻豆| 精品成人佐山爱一区二区| kk眼镜猥琐国模调教系列一区二区 | 国产日韩v精品一区二区| 欧美日韩dvd在线观看| 2020国产精品久久精品美国| 日韩丝袜美女视频| 色乱码一区二区三区88| 日韩电影免费在线看| 国产精品一二二区| av一区二区不卡| 中文字幕精品一区二区精品绿巨人 | 午夜精品久久久久久不卡8050| 欧美一区二区久久| 色噜噜狠狠色综合中国| 久久99精品视频| 亚洲第一综合色| 中文字幕一区二区日韩精品绯色| 91蜜桃网址入口| 国内成人精品2018免费看| 亚洲成人av在线电影| 中文字幕一区二区三区四区| www欧美成人18+| 盗摄精品av一区二区三区| 亚洲精品中文字幕在线观看| 精品一区精品二区高清| 国产精品一二三四区| 91九色最新地址| 精品日韩一区二区三区| 亚洲va中文字幕| 成人动漫av在线| 日韩欧美成人激情| 一区二区三区在线视频观看 | 8v天堂国产在线一区二区| 欧美裸体一区二区三区| 日韩一区欧美一区| 成人av在线网| 日韩精品资源二区在线| 亚洲成人av福利| av午夜精品一区二区三区| 日韩亚洲电影在线| 五月婷婷综合激情| 一本久久精品一区二区| 天天综合天天综合色| 成人午夜激情影院| 精品嫩草影院久久| 国产精品99久久久久久似苏梦涵 | 亚洲一级二级三级在线免费观看| 日本道在线观看一区二区| 麻豆精品视频在线观看免费| 亚洲婷婷国产精品电影人久久| 8v天堂国产在线一区二区| 国产在线看一区| 国产亚洲欧美在线| 91丨九色丨尤物| 亚洲图片欧美色图| 欧美巨大另类极品videosbest| 最新国产精品久久精品| 成人免费视频视频| 亚洲欧美日韩小说| 在线免费观看日本欧美| 亚洲精品中文在线观看| 在线观看欧美精品| 亚洲一区二区四区蜜桃| 91精品国产综合久久蜜臀 | 亚洲欧美另类小说视频| 色综合欧美在线视频区| 亚洲国产裸拍裸体视频在线观看乱了| 欧美日韩国产高清一区| 图片区小说区国产精品视频| wwwwww.欧美系列| 欧美最猛黑人xxxxx猛交| 麻豆国产欧美一区二区三区| 亚洲欧洲日韩一区二区三区| 欧美老肥妇做.爰bbww| 奇米888四色在线精品| 一区二区三区欧美在线观看| 久久亚洲欧美国产精品乐播| 欧美人妖巨大在线| 国产精品一区二区视频| 亚洲色图清纯唯美| 欧美久久久一区| 国产精品99久| 美女网站色91| 亚洲宅男天堂在线观看无病毒| 欧美日韩国产天堂| 91视频com| www..com久久爱| 久久99精品久久久久久动态图| 亚洲第一狼人社区| 亚洲欧美激情视频在线观看一区二区三区| 日韩一区二区在线免费观看| 91一区二区在线观看| 成人激情文学综合网| 国产成人鲁色资源国产91色综| 精品在线观看免费| 美女视频一区在线观看| 日韩二区在线观看| 久久99深爱久久99精品| 精品中文av资源站在线观看| 成人亚洲一区二区一| 成人免费毛片aaaaa**| 欧美视频一区二区三区四区| 精品国产精品一区二区夜夜嗨| 成人欧美一区二区三区1314| 亚洲va国产va欧美va观看| 狂野欧美性猛交blacked| 97精品国产97久久久久久久久久久久| 5858s免费视频成人| 91黄色激情网站| 欧美久久一区二区| 国产亚洲精品中文字幕| 亚洲天天做日日做天天谢日日欢| 一级精品视频在线观看宜春院| 肉色丝袜一区二区| 国产盗摄女厕一区二区三区 | 3atv一区二区三区| 久久综合狠狠综合久久激情| 亚洲欧美区自拍先锋| 美国三级日本三级久久99| 91热门视频在线观看| 精品久久久久久久久久久久久久久久久 | 国产免费成人在线视频| 亚洲小说春色综合另类电影| 日本一道高清亚洲日美韩| 国产精华液一区二区三区| 91麻豆免费观看| 欧美mv和日韩mv国产网站| 久久久国际精品| 亚洲一区二区三区在线| 9久草视频在线视频精品| 91 com成人网| 亚洲激情av在线| 国产成人精品午夜视频免费| 欧美日韩精品福利| 国产精品久久久久久亚洲伦| 国产精品88av| 日韩精品一区国产麻豆| 亚洲第一主播视频| 一本色道久久综合亚洲91| 国产精品国产成人国产三级| 免费成人av在线播放| 91丝袜美腿高跟国产极品老师 | 成人免费va视频| 精品欧美一区二区久久| 午夜成人免费视频| 日本高清不卡aⅴ免费网站| 国产精品嫩草99a| 国产一区二区伦理| 国产蜜臀97一区二区三区| 麻豆精品视频在线观看免费| 欧美三级日韩三级| 日韩国产欧美在线播放| 在线欧美小视频| 日韩av不卡在线观看| 欧美高清www午色夜在线视频| 丝袜美腿一区二区三区| 日韩欧美在线123| 国模无码大尺度一区二区三区| 4438x亚洲最大成人网| 蜜臀av性久久久久av蜜臀妖精| 欧美无砖专区一中文字| 国产精品国产三级国产aⅴ入口| 99热国产精品| 亚洲大尺度视频在线观看| 久久只精品国产| 国产a精品视频| 亚洲在线免费播放| 欧美久久久久免费| 国产成人一级电影| 国产视频一区二区在线| 91麻豆精品一区二区三区| 麻豆精品新av中文字幕| 国产亚洲成年网址在线观看| 丁香网亚洲国际| 国产精品亚洲专一区二区三区 | 久久不见久久见免费视频7| 8x福利精品第一导航| 99久久免费国产| 久久99精品久久久久婷婷| 国产精品久久久久国产精品日日| 日韩写真欧美这视频| 99久久精品国产导航| 成人国产精品免费观看视频| 国产专区综合网| 日本一区中文字幕| 亚洲午夜在线观看视频在线| 最近中文字幕一区二区三区| 精品福利一区二区三区| 欧美一区二区三区色| 99热99精品| 国产99一区视频免费| 蜜臀99久久精品久久久久久软件| 亚洲一区在线观看视频| 亚洲国产精品精华液2区45| 久久久久国产精品厨房| 国产网站一区二区三区| 欧美激情中文字幕| 日韩美女久久久|