我們都知道redis是采用C語(yǔ)言開發(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打開,接下來(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)在你可以整合一下博客開始處的:
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í)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- Redis的5種數(shù)據(jù)類型與常用命令講解
- Redis安裝及基本數(shù)據(jù)類型
- Redis中3種特殊的數(shù)據(jù)類型(BitMap、Geo和HyperLogLog)
- Jedis對(duì)redis的五大類型操作代碼詳解
- redis數(shù)據(jù)類型_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- Redis有序集合類型的操作_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- redis列表類型_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- redis集合類型_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- redis哈希類型_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- Redis 數(shù)據(jù)類型的詳解
- Redis中五種數(shù)據(jù)類型簡(jiǎn)單操作
- Redis集合類型的常用命令小結(jié)
- Redis列表類型的常用命令小結(jié)
- Redis中散列類型的常用命令小結(jié)
- Redis字符串類型的常用命令小結(jié)
- Redis有序集合類型的常用命令小結(jié)
- Redis02 使用Redis數(shù)據(jù)庫(kù)(String類型)全面解析
- redis基本類型和使用方法詳解