• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            redis源碼剖析-字符串

            redis源碼剖析-字符串

            redis實(shí)現(xiàn)了自己的字符串結(jié)構(gòu)。在文件sds.h/dsd.c中定義。redis中的字符串叫sds(simple dynamic string)。
            sds實(shí)質(zhì)是char*:
            typedef char *sds;
            sds通過(guò)sdsnewlen()函數(shù)來(lái)創(chuàng)建,sds sdsnewlen(const void *init, size_t initlen)。該函數(shù)內(nèi)部會(huì)創(chuàng)建一個(gè)sdshdr的結(jié)構(gòu),返回值sds,即char *,該結(jié)構(gòu)定義如下:
            struct sdshdr
            {
                    int len;
                    int free;
                    char buf[];
            };
            其中l(wèi)en存儲(chǔ)當(dāng)前字符串的長(zhǎng)度,free存儲(chǔ)該結(jié)構(gòu)體剩余可存儲(chǔ)字節(jié)數(shù),buf存儲(chǔ)字符串值。sdsnewlen()函數(shù)在創(chuàng)建sdshdr后,會(huì)返回buf的地址(sdshdr->buf)。
            sdsnewlen()函數(shù)創(chuàng)建了字符串,并返回字符串地址sds,要使用sdshdr中的len和free,則需要獲取sdshdr結(jié)構(gòu)體的地址。如何根據(jù)獲得的sds得到sdshdr結(jié)構(gòu)體的地址呢?
            redis中參考了linux內(nèi)核關(guān)于通用list(list_head)的實(shí)現(xiàn)機(jī)制,實(shí)現(xiàn)方法如下:
            struct sdshdr *sh =  (void*) (sds-(sizeof(struct sdshdr)));
            sds是返回的字符串地址,即sdshdr->buf,用sds的地址減去其在結(jié)構(gòu)體中的偏移,即可得到sdshdr的地址。由于buf在sdshdr結(jié)構(gòu)體的最后,所以其偏移就是sizeof(len)+sizeof(free),該偏移恰好是sizeof(struct sdshdr)。
            如果buf在sdshdr中的位置是任意的,如何根據(jù)buf的地址獲取sdshdr的地址呢?實(shí)現(xiàn)如下:
            假設(shè)現(xiàn)在sdshdr聲明如下:
            struct sdshdr
            {
                    int len;
                    char buf[];
                    int free;       
            };
            則sdshdr地址如下獲取:
            int offset_buf = (int)((struct sdshdr *)0)->buf;      
            struct sdshdr *sh =(struct sdshdr *)( (int)sdsbuf - offset_buf);  
            其中sdsbuf是調(diào)用sdsnewlen()返回的buf地址。即 sds sdsbuf = sdsnewlen(...);
            ((struct sdshdr *)0)->buf 表示當(dāng)結(jié)構(gòu)體sdshdr在地址0時(shí),buf相對(duì)于sdshdr首地址的偏移。

            posted on 2012-07-03 00:59 MrRightLeft 閱讀(1451) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): redis

            <2012年7月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            導(dǎo)航

            統(tǒng)計(jì)

            隨筆分類(lèi)

            隨筆檔案

            文章分類(lèi)

            文章檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            2020最新久久久视精品爱| 久久精品国产半推半就| 久久久久久久综合综合狠狠| 国产精品成人无码久久久久久 | 久久久久亚洲AV成人片| 中文精品久久久久人妻不卡| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 成人国内精品久久久久影院VR| 精品久久久久久无码人妻热| 精品国产99久久久久久麻豆| 久久中文字幕一区二区| 欧美国产精品久久高清| 五月丁香综合激情六月久久| 久久噜噜电影你懂的| 伊人久久久AV老熟妇色| 久久精品国产精品亚洲精品| 一个色综合久久| 久久综合九色综合久99 | 久久一区二区三区99| 国产精品久久久久久吹潮| 久久精品国产只有精品66| 日韩人妻无码一区二区三区久久 | 久久久受www免费人成| 久久夜色精品国产噜噜噜亚洲AV| 国产成人精品久久亚洲| 久久精品国产亚洲AV忘忧草18| 亚洲国产天堂久久综合网站| 国产成人精品综合久久久| 久久精品国产精品亚洲毛片| 亚洲国产精品无码久久| 欧美黑人激情性久久| 性欧美大战久久久久久久 | 99久久婷婷国产综合亚洲| 国产精品亚洲综合久久| 久久亚洲国产精品123区| 91久久香蕉国产熟女线看| 久久久久久久尹人综合网亚洲| 久久久噜噜噜www成人网| 亚洲中文字幕久久精品无码APP| 中文成人无码精品久久久不卡| 麻豆久久|