redis字符串類型_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
我們都知道redis是采用C語(yǔ)言開(kāi)發(fā),那么在C語(yǔ)言中表示string都是采用char[]數(shù)組的,然后你可能會(huì)想,那還不簡(jiǎn)單,當(dāng)我執(zhí)行如下命令,肯定是直接塞給char[]數(shù)組的。
如果你真的這么想的話,會(huì)有幾個(gè)問(wèn)題就要過(guò)來(lái)砍你了,先我們來(lái)找一個(gè)redis手冊(cè),http://doc.redisfans.com/
第一:如果你每次都執(zhí)行Append函數(shù),那是不是redis的char[]每次都需要再次擴(kuò)容,這樣是不是每次都是耗時(shí)操作呢?
第二:如果你每次執(zhí)行String中的StrLen,那redis底層是不是每次都要遍歷char數(shù)組來(lái)得到結(jié)果呢?
一、 探索Redis中的String是如何存儲(chǔ)的
根據(jù)上面說(shuō)的那些小情況,所以redis的作者沒(méi)有那么傻,正常的邏輯應(yīng)該是在char[]數(shù)組的層面上自己再來(lái)封裝一層。
1. SDS結(jié)構(gòu)體
在redis里面是采用SDS(simple dynamic string)來(lái)封裝char[]的,這個(gè)也是redis存儲(chǔ)的最小單元,下一個(gè)問(wèn)題就是哪里能看得到呢?我在wget壓縮包的時(shí)候,里面就有redis源碼啦,據(jù)說(shuō)還只有3w多行,這就告訴我們,有什么問(wèn)題,自己動(dòng)手豐衣足食,對(duì)吧,為查找方便,我就把redis的源碼拖到window上用vs打開(kāi),接下來(lái)我們看看SDS長(zhǎng)成啥樣???
可以看到它是定義在redis源碼中的sds.h源文件中的,你可能會(huì)奇怪,這三個(gè)屬性是干嘛用的???下面我簡(jiǎn)單說(shuō)一下。
<1> len: 標(biāo)記char[]的長(zhǎng)度, 有點(diǎn)類似我們C#中List的length一個(gè)意思。
<2> free: 標(biāo)記char[]中未使用的元素個(gè)數(shù),就是有幾個(gè)空坑的意思。
<3>buf[]:存放元素的坑,不一定和元素的實(shí)際個(gè)數(shù)相等,比如前面說(shuō)的cnblogs。也有可能是[c][n][b][l][o][g][s][/0][][][]。
二、探索Redis對(duì)象(RedisObject)
前面說(shuō)到的SDS僅僅是char[]數(shù)組的封裝,并不能標(biāo)識(shí)redis中的5大類型,所以可想而知,redis還需要在SDS上面進(jìn)行封裝,所以就有了接下來(lái)的
RedisObject對(duì)象,我們先看看它長(zhǎng)成啥樣。
可以看到RedisObject是在redis.h源代碼文件中的,下面我簡(jiǎn)單說(shuō)說(shuō)type和ptr屬性,詳細(xì)的東西在后續(xù)說(shuō)。
<1> type 這個(gè)就是用來(lái)標(biāo)識(shí)redisObject是哪種類型,既然是哪種類型,肯定就有一個(gè)類型枚舉,對(duì)吧,肯定有了,給你看看。
<2> *ptr 可以看到這玩意還是個(gè)指針類型,它所指向的內(nèi)存地址,你應(yīng)該也知道了,就是所謂的SDS枚舉類型。
好了,到現(xiàn)在你可以整合一下博客開(kāi)始處的:
127.0.0.1:6379> set name cnblogs OK 127.0.0.1:6379> get name "cnblogs" 127.0.0.1:6379>
針對(duì)上面的set命令,redis其實(shí)會(huì)創(chuàng)建兩個(gè)RedisObject對(duì)象,鍵的RedisObject 和值的RedisOjbect其中它們的type=REDIS_STRING ,也就都是字符串對(duì)象類型,其中的SDS分別存儲(chǔ)的就是name和cnblogs的字符咯,好了,大概就這樣了。
三、挑選幾個(gè)有意思的命令
1. incr,incrby,decr,decrby
這四個(gè)命令有點(diǎn)像C#中的Interlocked類的方法,如果你了解Interlocked,你應(yīng)該就知道下面有各種原子自增,自減等等方法,如下圖:
redis這個(gè)自增有什么好處呢?我覺(jué)得用這個(gè)生成訂單號(hào)還是蠻好的,我記得在攜程的時(shí)候,生成訂單號(hào)是專門的一個(gè)OrderIDDB中的func函數(shù)來(lái)生成的,這樣OrderID是不依賴于任何業(yè)務(wù)庫(kù)的,然后我們就可以相對(duì)方便的分庫(kù)分表了,現(xiàn)在用redis這樣做也挺好的。
其他的一些命令也沒(méi)什么好說(shuō)的了,大家可以對(duì)照redis手冊(cè)看一看就好了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
redis中scan命令的基本實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于redis中scan命令的基本實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10淺談redis采用不同內(nèi)存分配器tcmalloc和jemalloc
下面小編就為大家?guī)?lái)一篇淺談redis采用不同內(nèi)存分配器tcmalloc和jemalloc。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-12-12如何使用gradle將java項(xiàng)目推送至maven中央倉(cāng)庫(kù)
本文主要介紹了使用gradle將java項(xiàng)目推送至maven中央倉(cāng)庫(kù),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09redis中List列表常見(jiàn)命令及使用場(chǎng)景
這篇文章主要給大家介紹了關(guān)于redis中List列表常見(jiàn)命令及使用場(chǎng)景的相關(guān)資料,Redis列表是簡(jiǎn)單的字符串列表,按照插入順序排序,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01Redis從單點(diǎn)到集群部署模式(單機(jī)模式?主從模式?哨兵模式)
這篇文章主要為大家介紹了Redis從單點(diǎn)集群部署模式(單機(jī)模式?主從模式?哨兵模式)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11高并發(fā)場(chǎng)景分析之redis+lua防重校驗(yàn)
這篇文章主要介紹了高并發(fā)場(chǎng)景分析之redis+lua防重校驗(yàn),本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07