亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫(kù)
1234下一頁(yè)
最近訪(fǎng)問(wèn)板塊 發(fā)新帖
查看: 21174 | 回復(fù): 37
打印 上一主題 下一主題

[C] 實(shí)現(xiàn)了一個(gè)文件+mmap的紅黑樹(shù),歡迎測(cè)試 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2009-09-29 11:38 |只看該作者 |倒序?yàn)g覽
用于對(duì)需要永久存儲(chǔ) 而且需要查找和排序的int類(lèi)數(shù)據(jù),好處是減少?gòu)奈募x數(shù)據(jù)在內(nèi)存構(gòu)建紅黑樹(shù)的時(shí)間 另外使用mmap保證修改內(nèi)存后磁盤(pán)文件會(huì)同步,無(wú)須手動(dòng)sync和再次寫(xiě)入文件。
一個(gè) mmtree文件里可以構(gòu)件2G個(gè)樹(shù)節(jié)點(diǎn).
可以通過(guò)mmtree_new_tree()生成新的樹(shù).
mmtree_insert()  寫(xiě)入新節(jié)點(diǎn) 如果old返回為非空表示存在該節(jié)點(diǎn)。
mmtree_find() 查找節(jié)點(diǎn)
mmtree_remove() 移除節(jié)點(diǎn)
。。。。

鏈接:
http://hispider.googlecode.com/s ... /src/utils/mmtree.h
http://hispider.googlecode.com/s ... /src/utils/mmtree.c
多線(xiàn)程使用添加這個(gè)文件 并且添加編譯選項(xiàng) -DHAVE_PTHREAD
http://hispider.googlecode.com/s ... /src/utils/mutext.h

應(yīng)某同學(xué)的建議放一個(gè)打包上來(lái),代碼測(cè)試有問(wèn)題盡快告訴我。

mmtree.h

  1. #ifndef _MMTREE_H
  2. #define _MMTREE_H
  3. #define MMTREE_INCRE_NUM   10000
  4. typedef struct _MTNODE
  5. {
  6.     int data;
  7.     int key;
  8.     int left;
  9.     int right;
  10.     int parent;
  11.     int color;
  12. }MTNODE;
  13. typedef struct _MTSTATE
  14. {
  15.     int left;
  16.     int current;
  17.     int total;
  18.     int qleft;
  19.     int qfirst;
  20.     int qlast;
  21. }MTSTATE;
  22. typedef struct _MMTREE
  23. {
  24.     off_t size;
  25.     void *start;
  26.     MTSTATE *state;
  27.     MTNODE *map;
  28.     int fd;
  29.     void *mutex;
  30. }MMTREE;
  31. void *mmtree_init(char *file);
  32. int mmtree_new_tree(void *mmtree, int key, int data);
  33. int mmtree_insert(void *mmtree, int *prootid, int key, int data, int *old);
  34. int mmtree_get(void *mmtree, int nodeid, int *key, int *data);
  35. int mmtree_find(void *mmtree, int rootid, int key, int *data);
  36. int mmtree_min(void *mmtree, int rootid, int *key, int *data);
  37. int mmtree_max(void *mmtree, int rootid, int *key, int *data);
  38. int mmtree_next(void *mmtree, int rootid, int nodeid, int *key, int *data);
  39. int mmtree_prev(void *mmtree, int rootid, int nodeid, int *key, int *data);
  40. int mmtree_set_data(void *mmtree, int nodeid, int data);
  41. void mmtree_view_tree(void *mmtree, int rootid, FILE *fp);
  42. void mmtree_remove(void *mmtree, int *prootid, int nodeid, int *key, int *data);
  43. void mmtree_remove_tree(void *mmtree, int rootid);
  44. void mmtree_close(void *mmtree);
  45. #endif
復(fù)制代碼

[ 本帖最后由 redor 于 2009-9-29 15:53 編輯 ]

mmtree.zip

5.35 KB, 下載次數(shù): 257

論壇徽章:
1
寅虎
日期:2014-11-30 21:25:54
2 [報(bào)告]
發(fā)表于 2009-09-29 12:04 |只看該作者
先頂了 現(xiàn)在還用不到這么高級(jí)的東東

論壇徽章:
0
3 [報(bào)告]
發(fā)表于 2009-09-29 13:34 |只看該作者
很強(qiáng)大

論壇徽章:
0
4 [報(bào)告]
發(fā)表于 2009-09-29 14:12 |只看該作者

論壇徽章:
0
5 [報(bào)告]
發(fā)表于 2009-09-29 15:21 |只看該作者
你不會(huì)覺(jué)得這倆一樣吧? 你數(shù)據(jù)結(jié)構(gòu), 他的那個(gè)ms搞復(fù)雜了,我這個(gè)是為了保存數(shù)據(jù)到磁盤(pán) 而且還能搞到內(nèi)存添加 查找 刪除。用于任何用途應(yīng)該都可以,不僅僅局限cache。
不過(guò)各自都有自己的特點(diǎn), 呵呵


原帖由 converse 于 2009-9-29 14:12 發(fā)表
http://72891.cn/viewthread.php?tid=1069566

論壇徽章:
0
6 [報(bào)告]
發(fā)表于 2009-09-29 15:32 |只看該作者
>>我這個(gè)是為了保存數(shù)據(jù)到磁盤(pán) 而且還能搞到內(nèi)存添加 查找 刪除

這些都可以做到,而且key可以使變長(zhǎng)的.

論壇徽章:
0
7 [報(bào)告]
發(fā)表于 2009-09-29 15:37 |只看該作者
key變成有什么好處?char *加一個(gè)長(zhǎng)度? 我基本不贊同使用char * 作為key, 做之前最好使用相應(yīng)的轉(zhuǎn)換成int,不然效率損傷很大。

原帖由 converse 于 2009-9-29 15:32 發(fā)表
>>我這個(gè)是為了保存數(shù)據(jù)到磁盤(pán) 而且還能搞到內(nèi)存添加 查找 刪除

這些都可以做到,而且key可以使變長(zhǎng)的.

論壇徽章:
0
8 [報(bào)告]
發(fā)表于 2009-09-29 15:50 |只看該作者
在連續(xù)空間實(shí)現(xiàn)紅黑樹(shù),不錯(cuò)。不過(guò)變長(zhǎng)索引還是有必要的吧,畢竟字符串轉(zhuǎn)換成int后,信息量大大減少了。

論壇徽章:
0
9 [報(bào)告]
發(fā)表于 2009-09-29 15:55 |只看該作者
原帖由 cugb_cat 于 2009-9-29 15:50 發(fā)表
在連續(xù)空間實(shí)現(xiàn)紅黑樹(shù),不錯(cuò)。不過(guò)變長(zhǎng)索引還是有必要的吧,畢竟字符串轉(zhuǎn)換成int后,信息量大大減少了。



主要看你怎么變int了用hash變int肯定麻煩, 用trie變int就沒(méi)有沖突了,都是一一對(duì)應(yīng)的。

論壇徽章:
0
10 [報(bào)告]
發(fā)表于 2009-09-29 16:07 |只看該作者
原帖由 redor 于 2009-9-29 15:55 發(fā)表



主要看你怎么變int了用hash變int肯定麻煩, 用trie變int就沒(méi)有沖突了,都是一一對(duì)應(yīng)的。

還有你這個(gè)封裝對(duì)空間的使用率是個(gè)什么情況?
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專(zhuān)區(qū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過(guò)ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP