青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

那誰的技術博客

感興趣領域:高性能服務器編程,存儲,算法,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 那誰 閱讀(4883) 評論(0)  編輯 收藏 引用 所屬分類: tokyo cabinet

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            在线亚洲免费视频| 蜜臀av在线播放一区二区三区| 欧美一区二区三区视频在线| 一区二区三区欧美在线观看| 夜夜夜久久久| 午夜精品国产精品大乳美女| 亚洲欧美精品suv| 久久国产精品久久久| 久久亚洲一区二区三区四区| 欧美www视频| 日韩午夜激情av| 欧美中文在线观看国产| 欧美承认网站| 国产乱码精品1区2区3区| 激情久久久久久久| 一区二区三区波多野结衣在线观看| 中文av一区特黄| 久久久7777| 亚洲麻豆视频| 午夜精品久久久久久久蜜桃app| 久久久久久久成人| 欧美四级伦理在线| 在线免费观看日本一区| 亚洲一区二区三区四区视频| 久久蜜臀精品av| 亚洲毛片一区二区| 久久久久久午夜| 国产精品一卡二卡| 一本一本大道香蕉久在线精品| 久久九九久久九九| 亚洲午夜av| 欧美精品一区二区三区久久久竹菊| 国产日韩成人精品| 亚洲一区观看| 亚洲韩国精品一区| 欧美一区国产二区| 国产精品啊v在线| 亚洲人成人一区二区在线观看| 欧美一区二区在线播放| 亚洲最新在线| 欧美乱妇高清无乱码| 精品二区久久| 欧美亚洲视频一区二区| 亚洲欧洲精品一区二区精品久久久| 久久成人资源| 国产日韩亚洲| 久久国产欧美精品| 国产精品久久久久久久久久尿| 久久精品亚洲一区| 国产精品美女久久久免费| 亚洲区国产区| 欧美二区在线播放| 另类图片综合电影| 在线看欧美日韩| 欧美freesex交免费视频| 欧美在线不卡| 一区精品在线播放| 欧美.www| 欧美极品影院| 一本色道久久加勒比精品| 91久久久亚洲精品| 欧美日韩精品一本二本三本| 亚洲精品中文字| 亚洲黄一区二区| 欧美日韩成人在线观看| 一本久道综合久久精品| 亚洲精品视频一区二区三区| 欧美伦理影院| 亚洲综合国产激情另类一区| 在线视频欧美日韩| 国产精品亚洲欧美| 久久午夜影视| 欧美成va人片在线观看| 日韩亚洲在线观看| 中文在线资源观看视频网站免费不卡| 欧美日韩无遮挡| 性色av一区二区三区红粉影视| 午夜日韩福利| 亚洲国产成人一区| 99热精品在线| 国产一区美女| 亚洲激情视频在线| 国产精品一区二区久激情瑜伽| 久久久亚洲欧洲日产国码αv| 猛干欧美女孩| 午夜一级在线看亚洲| 久久久综合视频| 一区二区三区日韩精品视频| 亚洲欧美日韩爽爽影院| 亚洲风情在线资源站| 日韩图片一区| 一色屋精品亚洲香蕉网站| 亚洲青涩在线| 国产主播精品在线| 日韩一级黄色片| 黑人操亚洲美女惩罚| 亚洲区欧美区| 国产一区二区三区久久 | 亚洲无线观看| 亚洲一级电影| 在线观看一区二区视频| 日韩视频在线永久播放| 国内精品一区二区三区| 亚洲精品资源| 在线看日韩av| 欧美亚洲免费电影| 欧美激情在线有限公司| 欧美午夜影院| 免费成人av| 国产精品手机在线| 欧美成人首页| 国产日韩欧美综合| 制服丝袜亚洲播放| 亚洲精品影院在线观看| 久久精品久久99精品久久| 亚洲影院污污.| 美日韩精品免费| 久久这里有精品视频| 国产精品久久久久免费a∨| 亚洲第一在线综合在线| 狠狠色狠狠色综合人人| 午夜国产精品视频| 新狼窝色av性久久久久久| 欧美激情亚洲激情| 欧美激情偷拍| 亚洲第一在线视频| 久久综合狠狠综合久久综合88| 久久精品一区二区三区四区| 国产精品日韩高清| 亚洲伊人久久综合| 亚洲欧美美女| 国产精品入口日韩视频大尺度| 在线视频免费在线观看一区二区| 日韩性生活视频| 欧美精品国产一区二区| 最新热久久免费视频| 亚洲精品色图| 欧美日韩成人在线观看| 亚洲精品在线视频| 亚洲一区免费看| 国产精品入口麻豆原神| 午夜影视日本亚洲欧洲精品| 欧美在线观看视频在线| 国产亚洲福利一区| 久久精品1区| 欧美a级片网| 99精品视频免费观看| 欧美日韩视频在线第一区| 一本色道久久加勒比精品| 亚洲免费视频在线观看| 国产麻豆视频精品| 欧美与欧洲交xxxx免费观看 | 日韩视频一区| 欧美日韩精品免费在线观看视频| 一区二区三区日韩精品视频| 亚洲男人av电影| 国产日韩在线一区二区三区| 欧美自拍丝袜亚洲| 欧美国产日韩一二三区| 99re8这里有精品热视频免费| 欧美日本不卡| 午夜亚洲福利在线老司机| 免费看亚洲片| 亚洲中字黄色| 亚洲动漫精品| 欧美日韩综合在线| 欧美中文字幕精品| 91久久精品国产91久久性色tv| 亚洲一区二区三区成人在线视频精品| 国产精品美腿一区在线看| 久久久久一区二区三区四区| 亚洲国产精品成人一区二区 | 亚洲黄一区二区三区| 一区二区高清视频| 国产精品亚洲综合色区韩国| 久久亚洲风情| 在线亚洲自拍| 欧美成人午夜激情| 午夜免费电影一区在线观看| 极品av少妇一区二区| 欧美欧美全黄| 久久久噜久噜久久综合| 夜夜嗨av色一区二区不卡| 老司机一区二区三区| 亚洲一区二区综合| 亚洲精品日韩久久| 伊人狠狠色j香婷婷综合| 国产精品久久亚洲7777| 免费在线日韩av| 久久精品女人| 亚洲男人的天堂在线aⅴ视频| 亚洲激情网址| 欧美岛国激情| 久久频这里精品99香蕉| 欧美亚洲综合另类| 亚洲午夜小视频| 99精品国产在热久久下载| 亚洲高清一区二| 极品少妇一区二区三区| 国产日韩欧美自拍|