wangzhengquan
2020-07-28 51be606cae24b3f6de088ec59f69c378ceec0908
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
#ifndef __HASHTABLE_H__
#define __HASHTABLE_H__
 
#include <sys/queue.h>
#include <set>
 
#define MAPSIZE 100
 
typedef struct hashtable_t
{
 struct tailq_header_t* array[MAPSIZE];
 int mutex;
 int wlock;
 int cond;
 size_t readcnt;
 
} hashtable_t;
typedef void (*hashtable_foreach_cb)(int key, void *value);
 
void hashtable_init(hashtable_t *hashtable);
void *hashtable_get(hashtable_t *hashtable, int key);
void hashtable_put(hashtable_t *hashtable, int key, void *value);
void *hashtable_remove(hashtable_t *hashtable, int key);
void hashtable_removeall(hashtable_t *hashtable);
 
/** 
 * 遍历hash_table
 * @demo 
 * hashtable_foreach(&hashtable, [&](int key, void * value){
 *    printf("%d, %p\n", key, value);
 * });
 * 
*/
void hashtable_foreach(hashtable_t *hashtable, hashtable_foreach_cb cb);
 
// void hashtable_printall(hashtable_t *hashtable);
 
int hashtable_alloc_key(hashtable_t *hashtable);
 
std::set<int> * hashtable_keyset(hashtable_t *hashtable) ;
#endif