• <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>

            那誰的技術博客

            感興趣領域:高性能服務器編程,存儲,算法,Linux內核
            隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
            數據加載中……

            這是tokyo cabinet的一個BUG么

            最近在研讀tokyo cabinet的代碼,但是發現一個問題。
            目前在跟進的是使用hash table實現的數據庫文件,在項目的examples目錄下面有一些作者寫的demo文件演示如何使用的。我使用這里的tchdbex.c文件跟蹤代碼的運行情況,不過在里面加入了下面兩行代碼:
            /* store records */
              
            if(!tchdbput2(hdb, "foo""hop"||
                 
            !tchdbput2(hdb, "bar""step"||
                 
            !tchdbput2(hdb, "baz""jump")){
                ecode 
            = tchdbecode(hdb);
                fprintf(stderr, 
            "put error: %s\n", tchdberrmsg(ecode));
              }

            +  tchdbout2(hdb, "foo");
            +  tchdbput2(hdb, "foo""hop");

            (代碼前面加上+號的是我加上的兩行代碼)

            可以看到,我在加入了記錄(“foo”, “hop”)之后,對它進行了刪除操作,在這之后緊跟著再次插入相同的記錄。
            tokyo cabinet的hash-table實現中,刪除一條記錄時會將塌存放到一個free pool類型的數組中,這里面保存了這條刪除記錄的大小和在文件中的偏移量。

            問題在于,在加入記錄時,記錄的大小是32byte,刪除記錄時理所當然的也是刪除一條大小為32byte的記錄了,但是呢,緊跟著再次插入同樣的記錄時,代碼中(tchdb.c):
            3417      rec.rsiz = HDBMAXHSIZ + ksiz + vsiz;
            3418      if(!tchdbfbpsearch(hdb, &re
            3417行算出這條新插入的記錄應該是38byte,于是走入下面的函數tchdbfbpsearch 查找能滿足這個大小的freepool,之前返回的freepool是32,于是這個查找失敗了,不得不重新分配空間來存放這個新的記錄,而不是復用已經返回的空間---盡管前后兩次插入的數據大小是一樣的。
            其實,在上面的代碼中,第二次插入記錄的時候,查找可用的freepool失敗之后繼續往下走,最后真正插入到文件中的數據記錄大小還是32的。

            我給作者發去郵件,咨詢這個問題,作者的回答大意是說我描述的這個現象確實存在,不過是有一定的考慮在里面的,后期會進行一些改進。我沒有完全的把這部分代碼閱讀完畢,所以也就不好多說什么了,下面附上郵件內容,做一個記錄,也為可能會發現這個問題的朋友提個醒吧。

            我使用的版本是1.4.19。
            chuang
             發送至 hirarin
                
            顯示詳細信息 
            15:10 (6 小時前)
                
            Hi, hirarin,recently, I 
            try to read and trace the tokyocabinet source.
            when I use the examples
            /tchdbex.c to trace hash-table, I find a problem.

            In the file tchdbex.c, I add two lines:
              
            /* store records */
              
            if(!tchdbput2(hdb, "foo""hop"||
                 
            !tchdbput2(hdb, "bar""step"||
                 
            !tchdbput2(hdb, "baz""jump")){
                ecode 
            = tchdbecode(hdb);
                fprintf(stderr, 
            "put error: %s\n", tchdberrmsg(ecode));
              }

            +  tchdbout2(hdb, "foo");
            +  tchdbput2(hdb, "foo""hop");

            so, you can see that after insert key 
            "foo","bar" and "baz", I try to remove the record with the key "foo", and then insert record ("foo","hop") again.

            But, when i use gdb to trace the program, i find that, when i first insert the record (
            "foo""hop"), the record size is 32.
            and then, when i remove the record (
            "foo""hop"), the record size is 32, it is ok, then a free block with size 32 is inserted into the free block arrays.
            But, when I insert record (
            "foo""hop") once again, in the file tchdb.c:3417:
            3417      rec.rsiz = HDBMAXHSIZ + ksiz + vsiz;
            then the record size 
            is 38
            and then the next line it tries to find a free block fix to 
            this size, but there is only free block with size 32, so it is falied to find a free block.

            I mean that, 
            if I remove the record ("foo""hop") and then try to insert it again, seems that it should use the free block with size 32.Otherwise, there will be missing retrieval of the free block.

            So, 
            is it a bug??

            BTW: the version 
            is 1.4.19
             
            |
            Mikio Hirabayashi
             發送至 我
                
            顯示詳細信息 
            16:37 (5 小時前)
                
            Hi,

            Thanks 
            for the report.
            It
            's not a bug but on purpose.
            The header size is not calcurated at the line, I estimate it the
            maximum size 
            in theory.
            However, I hit on an idia thanks to you.  I
            'll change the logic to
            reduce the file size.

            Regards.



            posted on 2009-12-03 22:09 那誰 閱讀(4876) 評論(0)  編輯 收藏 引用 所屬分類: tokyo cabinet

            熟妇人妻久久中文字幕| 亚洲国产精品高清久久久| 久久久噜噜噜www成人网| 久久精品午夜一区二区福利| 久久精品人人做人人爽97| 国产精品久久久天天影视| 亚洲国产成人久久一区久久| 久久亚洲中文字幕精品有坂深雪| 国产亚洲美女精品久久久| 久久久久高潮综合影院| 日本精品久久久久中文字幕| 久久婷婷五月综合97色直播| 99久久久国产精品免费无卡顿| 伊人久久大香线蕉av不变影院| 久久精品国产99久久丝袜| 久久国产精品国产自线拍免费| 性做久久久久久久久浪潮| 久久久国产精品福利免费| 久久毛片一区二区| 狠狠色婷婷综合天天久久丁香 | 国产精品美女久久久久av爽| 久久精品国产91久久综合麻豆自制 | 亚洲欧洲精品成人久久曰影片| 久久久久AV综合网成人| 2021国内久久精品| 狠狠色丁香婷婷久久综合五月| 日本免费一区二区久久人人澡| 国产精品女同久久久久电影院| 久久99久国产麻精品66| 伊人久久大香线蕉精品不卡| 久久久久99精品成人片三人毛片| 久久久青草青青亚洲国产免观| 欧美丰满熟妇BBB久久久| 青青草原综合久久大伊人| 亚洲欧美久久久久9999| 一本大道久久香蕉成人网| 欧洲国产伦久久久久久久| 思思久久99热只有频精品66| 伊人 久久 精品| 亚洲国产另类久久久精品 | 久久精品国产亚洲综合色|