-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathmain.cpp
67 lines (54 loc) · 1.37 KB
/
main.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "mem_hash.h"
using namespace mem_hash;
const uint32_t BUF_LEN = 5376;
MemHash *mem;
void test_for_mem_hash_stat()
{
uint32_t node_used_perct = 0;
uint32_t block_used_perct = 0;
mem->Stat(node_used_perct, block_used_perct);
printf("node_used_perct = %u block_used_perct = %u\n", node_used_perct, block_used_perct);
}
void test_for_mem_hash_foreachkey()
{
uint64_t key = 0;
while(mem->ForEachKey(key))
printf("%lu\n", key);
}
void test_for_mem_hash_meta()
{
uint32_t bucket_time, bucket_len, max_block;
mem->Meta("zfz.memhash", bucket_time, bucket_len, max_block);
printf("bucket_time = %u bucket_len = %u max_block = %u\n", bucket_time, bucket_len, max_block);
}
void test_for_mem_hash_set(uint64_t key, char *p)
{
mem->Set(key, p, BUF_LEN);
}
void test_for_mem_hash_del(uint64_t key)
{
mem->Del(key);
}
int main ()
{
char data[BUF_LEN];
memset(data, 'a', BUF_LEN);
data[BUF_LEN - 1] = 0;
mem = new MemHash();
mem->Init("zfz.memhash", 3600, mem_hash::OPEN_MLOCK, 10000, MS_ASYNC, 50, 100000, 500000);
for (uint64_t i = 1; i <= 100000; i++) {
//uint64_t rand_key = (uint64_t)rand();
test_for_mem_hash_set(i, data);
}
for(uint64_t i = 1; i <= 100000; i++) {
test_for_mem_hash_del(i);
}
test_for_mem_hash_meta();
test_for_mem_hash_stat();
test_for_mem_hash_foreachkey();
delete mem;
return 0;
}