精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

阿里面試這樣問:Redis為什么把簡(jiǎn)單的字符串設(shè)計(jì)成SDS?

數(shù)據(jù)庫(kù) 其他數(shù)據(jù)庫(kù) Redis
2021開工第一天,就有小伙伴私信我,還給我分享了一道他面阿里的redis題,題目很簡(jiǎn)單,是那種典型的似懂非懂,這里整理出來分享一下,順便自己鞏固一下基礎(chǔ),希望對(duì)正在面試和想要面試的兄弟有點(diǎn)幫助。

2021開工第一天,就有小伙伴私信我,還給我分享了一道他面阿里的redis題(這家伙絕比已經(jīng)拿到年終獎(jiǎng)了),我看了以后覺得挺有意思,題目很簡(jiǎn)單,是那種典型的似懂非懂,常常容易被大家忽略的問題。這里整理出來分享一下,順便自己鞏固一下基礎(chǔ),希望對(duì)正在面試和想要面試的兄弟有點(diǎn)幫助。

題目大致是這樣的

面試官:了解redis的String數(shù)據(jù)結(jié)構(gòu)底層實(shí)現(xiàn)嘛?

鐵子:當(dāng)然知道,是基于SDS實(shí)現(xiàn)的

面試官:redis是用C語(yǔ)言開發(fā)的,那為啥不直接用C的字符串,還單獨(dú)設(shè)計(jì)SDS這樣的結(jié)構(gòu)呢?

鐵子:·····

[[383116]]

 其實(shí)看得出面試官是想看看,鐵子是只停留在redis的使用層面,還是對(duì)底層數(shù)據(jù)結(jié)構(gòu)有過更深入的研究,面試嘛都愛這樣問大家都懂得。

我們知道redis是用C寫的,但它卻沒有完全直接使用C的字符串,而是自己又重新構(gòu)建了一個(gè)叫簡(jiǎn)單動(dòng)態(tài)字符串SDS(simple dynamic string)的抽象類型。

redis也支持使用C語(yǔ)言的傳統(tǒng)字符串,只不過會(huì)用在一些不需要對(duì)字符串修改的地方,比如靜態(tài)的字符輸出。

而我們開發(fā)中使用redis,往往會(huì)經(jīng)常性的修改字符串的值,這個(gè)時(shí)候就會(huì)用SDS來表示字符串的值了。有一點(diǎn)值得注意:在redis數(shù)據(jù)庫(kù)中,key-value鍵值對(duì)含有字符串值的,都是由SDS來實(shí)現(xiàn)的。

比如:在redis執(zhí)行一個(gè)最簡(jiǎn)單的set命令,這時(shí)redis會(huì)新建一個(gè)鍵值對(duì)。

  1. 127.0.0.1:6379> set xiaofu "程序員內(nèi)點(diǎn)事" 

此時(shí)鍵值對(duì)的key和value都是一個(gè)字符串對(duì)象,而對(duì)象的底層實(shí)現(xiàn)分別是兩個(gè)保存著字符串xiaofu和程序員內(nèi)點(diǎn)事的SDS結(jié)構(gòu)。

再比如:我向一個(gè)列表中壓入數(shù)據(jù),redis 又會(huì)新建一個(gè)鍵值對(duì)。 

  1. 127.0.0.1:6379> lpush xiaofu "程序員內(nèi)點(diǎn)事" "程序員小富" 

這時(shí)候鍵值對(duì)的鍵和上邊一樣,還是一個(gè)由SDS實(shí)現(xiàn)的字符串對(duì)象,鍵值對(duì)的值是一個(gè)包含兩個(gè)字符串對(duì)象的列表對(duì)象了,而這兩個(gè)對(duì)象的底層也是由SDS實(shí)現(xiàn)。

SDS結(jié)構(gòu)

一個(gè)SDS值的數(shù)據(jù)結(jié)構(gòu),主要由len、free、buf[]這三個(gè)屬性組成。 

  1. struct sdshdr{  
  2.   int free; // buf[]數(shù)組未使用字節(jié)的數(shù)量  
  3.   int len; // buf[]數(shù)組所保存的字符串的長(zhǎng)度  
  4.   char buf[]; // 保存字符串的數(shù)組  

其中buf[]為實(shí)際保存字符串的char類型數(shù)組;free表示buf[]數(shù)組未使用字節(jié)的數(shù)量;len表示buf[]數(shù)組所保存的字符串的長(zhǎng)度。

例如上圖表示的是buf[]保存長(zhǎng)度為6個(gè)字節(jié)的字符串,未使用的字節(jié)數(shù)free為0,但是眼尖的同學(xué)會(huì)發(fā)現(xiàn)這明明是7個(gè)字符,還有一個(gè)"\0"啊?

上邊提到過SDS沒有完全直接使用C的字符串,還是沿用了一些C特性的,比如遵循C的字符串以空格符結(jié)尾的規(guī)則,這樣還可以使用一部分C字符串的函數(shù)。而對(duì)于SDS來說,空字符串占用的一字節(jié)是不計(jì)算在len屬性里的,會(huì)為他分配額外的空間。

簡(jiǎn)單了解SDS結(jié)構(gòu)后,下邊我們來看看SDS相比于C字符串有哪些優(yōu)點(diǎn)。

效率高

舉個(gè)例子:工作中使用redis,經(jīng)常會(huì)通過STRLEN命令得到一個(gè)字符串的長(zhǎng)度,在SDS結(jié)構(gòu)中l(wèi)en屬性記錄了字符串的長(zhǎng)度,所以我們獲取一個(gè)字符串長(zhǎng)度直接取len的值,復(fù)雜度是O(1)。

而如果用C字符串,在獲取一個(gè)字符串長(zhǎng)度時(shí),需對(duì)整個(gè)字符串進(jìn)行遍歷,直至遍歷到空格符結(jié)束(C中遇到空格符代表一個(gè)完整字符串),此時(shí)的復(fù)雜度是O(N)。

在高并發(fā)場(chǎng)景下頻繁遍歷字符串,獲取字符串的長(zhǎng)度很有可能成為redis的性能瓶頸,所以SDS性能更好一些。

數(shù)據(jù)溢出

上邊提到C字符串是不記錄自身長(zhǎng)度的,相鄰的兩個(gè)字符串存儲(chǔ)的方式可能如下圖,為字符串分配了合適的內(nèi)存空間。

如果此時(shí)我想把“程序員內(nèi)點(diǎn)事”改成“程序員內(nèi)點(diǎn)事123”,可之前分配的內(nèi)存只有6個(gè)字節(jié),修改后的字符串需要9個(gè)字節(jié)才能放下啊,怎么搞?

沒辦法只能侵占相鄰字符串的空間,自身數(shù)據(jù)溢出導(dǎo)致其他字符串的內(nèi)容被修改。

而SDS很好的規(guī)避了這點(diǎn),當(dāng)我們需要修改數(shù)據(jù)時(shí),首先會(huì)檢查當(dāng)前SDS空間len是否滿足,不滿足則自動(dòng)擴(kuò)容空間至修改所需的大小,然后再執(zhí)行修改,如下圖所示。

不過有個(gè)特殊的地方,在把“程序員內(nèi)點(diǎn)事”的6個(gè)字節(jié)擴(kuò)容到“程序員內(nèi)點(diǎn)事123”9個(gè)字節(jié)后,發(fā)現(xiàn)free屬性的值變成了擴(kuò)容后字符串的總長(zhǎng)度,這就涉及到下邊要說的內(nèi)存重分配策略了。

內(nèi)存重分配策略

C字符串長(zhǎng)度是一定的,所以每次在增長(zhǎng)或者縮短字符串時(shí),都要做內(nèi)存的重分配,而內(nèi)存重分配算法通常又是一個(gè)比較耗時(shí)的操作,如果程序不經(jīng)常修改字符串還是可以接受的。

但很不幸,redis作為一個(gè)數(shù)據(jù)庫(kù),數(shù)據(jù)肯定會(huì)被頻繁修改,如果每次修改都要執(zhí)行一次內(nèi)存重分配,那么就會(huì)嚴(yán)重影響性能。

SDS通過兩種內(nèi)存重分配策略,很好的解決了字符串在增長(zhǎng)和縮短時(shí)的內(nèi)存分配問題。

1.空間預(yù)分配

空間預(yù)分配策略用于優(yōu)化SDS字符串增長(zhǎng)操作,當(dāng)修改字符串并需對(duì)SDS的空間進(jìn)行擴(kuò)展時(shí),不僅會(huì)為SDS分配修改所必要的空間,還會(huì)為SDS分配額外的未使用空間free,下次再修改就先檢查未使用空間free是否滿足,滿足則不用在擴(kuò)展空間。

通過空間預(yù)分配策略,redis可以有效的減少字符串連續(xù)增長(zhǎng)操作,所產(chǎn)生的內(nèi)存重分配次數(shù)。

額外分配未使用空間free的規(guī)則:

  •  如果對(duì) SDS 字符串修改后,len 值小于 1M,那么此時(shí)額外分配未使用空間 free 的大小與len相等。
  •  如果對(duì) SDS 字符串修改后,len 值大于等于 1M,那么此時(shí)額外分配未使用空間 free 的大小為1M。

2.惰性空間釋放

惰性空間釋放策略則用于優(yōu)化SDS字符串縮短操作,當(dāng)縮短SDS字符串后,并不會(huì)立即執(zhí)行內(nèi)存重分配來回收多余的空間,而是用free屬性將這些空間記錄下來,如果后續(xù)有增長(zhǎng)操作,則可直接使用。

數(shù)據(jù)格式多樣性

C字符串中的字符必須符合某些特定的編碼格式,而且上邊我們也提到,C字符串以\0空字符結(jié)尾標(biāo)識(shí)一個(gè)字符串結(jié)束,所以字符串里邊是不能包含\0的,不然就會(huì)被誤認(rèn)是多個(gè)。

由于這種限制,使得C字符串只能保存文本數(shù)據(jù),像音視頻、圖片等二進(jìn)制格式的數(shù)據(jù)是無法存儲(chǔ)的。

redis 會(huì)以處理二進(jìn)制的方式操作Buf數(shù)組中的數(shù)據(jù),所以對(duì)存入其中的數(shù)據(jù)未做任何的限制、過濾,只要存進(jìn)來什么樣,取出來還是什么樣。

總結(jié)

上邊只是 redis 數(shù)據(jù)結(jié)構(gòu)的一點(diǎn)基礎(chǔ)知識(shí),沒什么難度,但以我的面試經(jīng)驗(yàn),如果被問這類問題,不要只含糊其辭的說出底層是SDS,有理有據(jù)的把為什么這樣實(shí)現(xiàn)也說出來。

一來可以顯得自己基本功扎實(shí),如果表達(dá)的在條理清晰,是個(gè)很不錯(cuò)的加分項(xiàng);在一個(gè)主動(dòng)打消面試官問下去的念頭,當(dāng)然就怕不按套路出牌的人! 

 

責(zé)任編輯:龐桂玉 來源: java版web項(xiàng)目
相關(guān)推薦

2021-02-18 07:45:09

redis 字符串SDS

2021-04-27 10:53:58

Redis數(shù)據(jù)庫(kù)SDS

2019-03-07 15:43:22

Redis數(shù)據(jù)SDS

2021-02-07 21:16:04

字節(jié)跳動(dòng)面試字符串

2020-05-13 12:17:33

RedisC字符C語(yǔ)言

2024-02-20 20:12:09

C語(yǔ)言字符串Redis

2020-07-23 16:00:38

Redis字符串Java

2024-05-27 08:04:41

2023-03-21 15:27:00

RedisC語(yǔ)言字符串

2024-05-27 08:01:15

2023-01-03 08:07:33

Go字符串指針

2023-09-21 10:50:23

MySQL數(shù)據(jù)庫(kù)

2015-03-19 15:04:06

2023-05-29 08:03:41

代碼Go語(yǔ)言

2019-02-27 09:00:13

阿里巴巴for循環(huán)Java

2019-01-29 10:30:32

阿里巴巴Java字符串

2025-06-16 08:10:00

2021-02-02 18:03:00

字符串面試官子序列

2020-12-16 07:36:46

Redis字符串數(shù)據(jù)

2025-06-11 08:35:00

數(shù)據(jù)倉(cāng)庫(kù)數(shù)倉(cāng)分層架構(gòu)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

含羞草www国产在线视频| 黄色激情在线观看| av在线免费观看网| 国产米奇在线777精品观看| 日韩有码视频在线| 色男人天堂av| 人人视频精品| 一区二区三区在线观看动漫| 久久精品国产精品青草色艺 | 国产精品电影观看| 免费在线观看一级片| 综合亚洲色图| 久久伊人影院| 亚洲人成亚洲人成在线观看图片| 精品一区二区视频| 国产女人18毛片水真多| 国产美女诱惑一区二区| 久久精品国产96久久久香蕉 | 国产欧美一区二区精品仙草咪| 国产中文日韩欧美| 无码人妻一区二区三区线| 国产伊人精品| 久久人人爽亚洲精品天堂| 播金莲一级淫片aaaaaaa| 在线观看视频一区二区三区| 欧美天天综合网| 奇米精品一区二区三区| 污污视频在线| 亚洲人xxxx| 亚洲人成网站在线播放2019| 欧美孕妇孕交| 92精品国产成人观看免费| 99国产视频| 国产日韩欧美一区二区东京热| 日韩国产欧美在线播放| 日本高清久久天堂| 日韩三级视频在线| 成人午夜免费影院| 国产精品亚洲综合在线观看| 欧美亚洲国产bt| 爱福利视频一区二区| 国产高清视频色在线www| 一区二区三区加勒比av| 中文字幕第50页| 国产在线激情视频| 中文字幕人成不卡一区| 亚洲精品国产系列| 91精彩在线视频| 国产亚洲一区字幕| 日韩欧美一区二区视频在线播放| 欧美成人综合在线| 久久综合中文字幕| 欧美在线一区二区三区四区| 日色在线视频| 久久精品这里都是精品| 亚洲午夜国产一区99re久久| 亚洲在线一区二区| 精品国产va久久久久久久| 色综合视频在线| 国内精品久久久久影院一蜜桃| 国产日韩中文字幕在线| 国产精品亚洲lv粉色| 国产乱人伦精品一区二区在线观看| 91亚洲精品久久久久久久久久久久| 国产精品羞羞答答在线| 成人性生交大合| 激情欧美一区二区三区中文字幕| 天堂a√中文在线| 久久久精品免费免费| 亚洲精品无人区| 国精产品一区| 欧美日韩国产区| 午夜精品在线免费观看| 九九久久国产| 日韩美女在线视频| 中文在线一区二区三区| 国产一区二区三区站长工具| www国产亚洲精品久久网站| 欧美日韩免费做爰视频| 国产精品久久777777毛茸茸| 国产成人久久久精品一区| 一级黄色大片免费| 国产不卡视频在线播放| 久久香蕉综合色| www一区二区www免费| 中文字幕在线观看网站| 亚洲h动漫在线| 爱情岛论坛vip永久入口| 成人av在线播放| 亚洲精品mp4| 亚洲图片第一页| 欧美日本一区二区视频在线观看| 欧美有码在线视频| 一级黄色片在线看| 91色porny在线视频| 一区二区三区视频| 高清在线视频不卡| 欧美日本国产视频| 99久久国产精| 中文字幕一区二区精品区| 2019中文字幕免费视频| 国产精品久久久久久免费播放| av在线不卡免费看| 美女黄色片网站| 桃色一区二区| 精品国产乱码久久久久久久| 国产欧美一区二区三区在线观看视频| 欧美视频导航| 国产区精品在线观看| 婷婷开心激情网| 亚洲男人都懂的| 9久久婷婷国产综合精品性色| 1313精品午夜理伦电影| 中文国产亚洲喷潮| 91看片在线播放| 国产美女主播视频一区| 少妇精品久久久久久久久久| 超碰99在线| 日韩一区二区精品| gv天堂gv无码男同在线观看| 国产欧美激情| 国产福利久久精品| 国产激情在线| 欧美精品一二三| 天天躁日日躁aaaxxⅹ| 无码国产69精品久久久久网站 | 精品一区二区三区三区| 在线观看视频91| 一区视频在线播放| 91一区一区三区| 久久99在线观看| 影音先锋国产精品| 久久一留热品黄| 国产一区二区三区高清视频| 秋霞影院午夜丰满少妇在线视频| 欧美日韩免费在线观看| 在线观看免费视频国产| 欧美成人69| 91久久在线观看| 老司机午夜在线视频| 欧美无砖砖区免费| 欧美激情视频二区| 久久最新视频| 欧洲一区二区日韩在线视频观看免费| 美女91在线看| 亚洲精品av在线| 欧美一二三区视频| 2020国产成人综合网| 黄色动漫网站入口| 米奇777超碰欧美日韩亚洲| 81精品国产乱码久久久久久| 日韩一级片免费观看| 午夜电影一区二区三区| v天堂中文在线| 亚洲一区二区毛片| 日韩jizzz| 国产a亚洲精品| 精品国产网站地址| 99久久夜色精品国产亚洲| 亚洲欧美一区二区三区极速播放 | 亚洲视频网站在线观看| 中文字幕精品视频在线观看| 国产欧美一区二区三区沐欲 | 国产精品一区二区免费福利视频 | 国产高清视频免费在线观看| 经典一区二区三区| 妺妺窝人体色www看人体| 9l视频自拍九色9l视频成人| 久久久亚洲影院你懂的| 午夜18视频在线观看| 色综合夜色一区| 男人天堂资源网| 国产九色精品成人porny| youjizz.com在线观看| 欧美人妖视频| 国产精品一区二区久久精品| 97超碰在线公开在线看免费| 亚洲第一精品电影| 日韩国产成人在线| 亚洲女爱视频在线| 精品少妇一区二区三区免费观| 日本中文一区二区三区| 潘金莲一级淫片aaaaaa播放1| 懂色av一区二区| 国产精品精品一区二区三区午夜版| 日日夜夜精品一区| 亚洲成人av在线播放| 成人小视频在线播放| 亚洲黄网站在线观看| 亚洲最大成人网站| 国产精一区二区三区| 男女午夜激情视频| 亚洲成人免费| 欧美福利一区二区三区| 国产精品视频首页| 日本精品免费一区二区三区| 成人日批视频| 亚洲人免费视频| 亚洲AV无码一区二区三区性| 色婷婷综合在线| 久草视频在线资源站| 久久精品视频一区二区三区| gogo亚洲国模私拍人体| 日韩av一二三| 国产精品自拍片| 女人色偷偷aa久久天堂| 欧美日韩精品不卡| 国产成人福利av| 成人黄色激情网| 日本中文字幕一区二区| 久久久视频在线| 黄色在线播放网站| 国产亚洲一级高清| 天堂av2024| 日韩欧美黄色影院| 一级黄色免费片| 欧美系列在线观看| 男人午夜免费视频| 性感美女久久精品| 欧美日韩免费一区二区| 综合中文字幕亚洲| 99在线视频免费| 久久久久久夜精品精品免费| 午夜精品一区二区三区视频免费看| 搜索黄色一级片| 国产视频一区在线观看| 少妇一级淫片免费放播放| 国产精品一卡二卡| 777一区二区| 美女视频一区二区三区| 日本久久久精品视频| 亚洲国产影院| 国产一区二区四区| 欧美韩国一区| www.69av| 好看的日韩av电影| 懂色av一区二区三区四区五区| 日韩激情图片| 亚洲精品日韩精品| 欧洲毛片在线视频免费观看| 蜜桃日韩视频| 亚洲影院天堂中文av色| 久久国产精品-国产精品| 国产精品网站在线看| av免费精品一区二区三区| 日韩成人18| 99re国产| 爱高潮www亚洲精品| 风间由美一区二区三区| 国产精品网站在线看| 国产精品嫩草在线观看| 豆花视频一区二区| 国内精品二区| 日本欧美三级| 欧美尤物一区| 久久伦理在线| 国产欧美综合一区| 欧美午夜精品| 国产黄色片免费在线观看| 日韩视频三区| 成人观看免费完整观看| 日日骚欧美日韩| 色七七在线观看| 美女视频一区二区三区| 亚洲色图偷拍视频| 国产精品88888| 娇妻高潮浓精白浆xxⅹ| 久久夜色精品国产噜噜av| av网在线播放| 亚洲欧洲日韩av| 久久久久久av无码免费网站| 午夜精品久久久久久久久久 | 在线观看免费成人| 91中文字幕在线播放| 91精品国产麻豆国产自产在线| www.蜜臀av| 亚洲欧美中文日韩在线v日本| 第一页在线观看| 大量国产精品视频| 欧美亚洲日本精品| 国产精品直播网红| 这里视频有精品| 欧美精品久久久| 综合精品久久| 精品人妻一区二区三区四区在线 | 欧美xxxxx精品| 国产欧美视频一区二区| 顶臀精品视频www| 精品国产31久久久久久| 日韩乱码一区二区三区| 91精品国产色综合久久不卡电影| 天天操天天干天天爽| 在线视频免费一区二区| 欧美一卡二卡| 国产精品美乳一区二区免费| 亚洲91网站| 日韩.欧美.亚洲| 欧美三区在线| 91精品无人成人www| 成人免费毛片a| 九一在线免费观看| 午夜视频在线观看一区二区| 中文字幕免费高清在线观看| 亚洲福利视频在线| 黄色网页在线播放| 欧美猛男超大videosgay| 伊人五月天婷婷| 波多野结衣在线一区| 糖心vlog免费在线观看| 欧美日韩中文字幕| 国内精品久久久久久久久久久| 国产一区二区三区视频在线观看| 超级碰碰不卡在线视频| 国产精品直播网红| 国产精品一区二区av日韩在线| 欧美另类videos| 蜜桃av噜噜一区二区三区小说| 国产二级一片内射视频播放| 亚洲欧洲av在线| 波多野结衣一二区| 亚洲国产中文字幕久久网| 成年人黄视频在线观看| 国产精品美女av| 伊人久久大香线蕉综合网站| 日韩精品一区在线视频| 国内国产精品久久| 成人一级片免费看| 在线观看亚洲一区| 久草在线青青草| 欧洲成人在线观看| 日本一道高清一区二区三区| www.亚洲成人网| 国产在线视频一区二区| 免费91在线观看| 欧美偷拍一区二区| 尤物视频在线免费观看| 国产精品久久久久7777婷婷| 久久91成人| 国产黄色特级片| www国产成人免费观看视频 深夜成人网| 久久成人国产精品入口| 欧美一区二区福利视频| 国产剧情在线| 亚洲bt天天射| 午夜精品av| 26uuu国产| 亚洲国产精品久久久久婷婷884| 精品人妻一区二区三区日产乱码| 久久中文字幕视频| 久久伊人久久| 美女扒开大腿让男人桶| av电影一区二区| 久久久久久久久久久影院| 日韩精品在线免费观看| 成年美女黄网站色大片不卡| 青娱乐一区二区| 日本欧美一区二区三区乱码| 91l九色lporny| 欧美日韩高清一区| av免费看在线| 成人资源av| 亚洲欧美日韩一区在线观看| 免费在线观看成年人视频| 色综合视频在线观看| 成年人视频在线免费观看| 国产免费一区二区三区在线观看| 国产精品x453.com| 亚洲精品乱码久久久久久9色| 亚洲成人7777| 青青草在线免费观看| 国产精品视频久久| 欧美在线资源| 国产中文字幕一区二区| 欧洲亚洲国产日韩| 国产黄色小视频在线| 亚洲人成影院在线观看| 中文字幕av影院| 自拍视频国产精品| 日韩在线成人| 免费毛片小视频| 日韩美女视频一区二区| 午夜精品一二三区| 日本一区二区不卡| 在线看片不卡| 欧类av怡春院| 欧美日本免费一区二区三区| 成人女同在线观看| 日韩国产高清一区| 国产v综合v亚洲欧| 黄色片中文字幕| 免费av一区二区| 一本色道久久综合亚洲精品酒店| 亚洲国产高清av| 亚洲成人自拍一区| 在线免费av网站| 好看的日韩精品视频在线| 麻豆91在线播放免费| 亚洲激情视频一区| 日韩中文字幕视频在线观看| 日韩aaa久久蜜桃av|