hash.h 4.6 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */

#ifndef TDENGINE_HASH_H
#define TDENGINE_HASH_H

H
hjxilinx 已提交
19 20 21 22
#ifdef __cplusplus
extern "C" {
#endif

H
Haojun Liao 已提交
23
#include "tarray.h"
H
hjxilinx 已提交
24
#include "hashfunc.h"
H
Haojun Liao 已提交
25
#include "tlockfree.h"
26 27 28 29 30

#define HASH_MAX_CAPACITY (1024 * 1024 * 16)
#define HASH_DEFAULT_LOAD_FACTOR (0.75)
#define HASH_INDEX(v, c) ((v) & ((c)-1))

H
hjxilinx 已提交
31 32
typedef void (*_hash_free_fn_t)(void *param);

33
typedef struct SHashNode {
H
Haojun Liao 已提交
34
//  char             *key;
35
  struct SHashNode *next;
H
Haojun Liao 已提交
36
  uint32_t          hashVal;  // the hash value of key
37
  uint32_t          keyLen;   // length of the key
H
Haojun Liao 已提交
38
//  char             *data;
39 40
} SHashNode;

H
Haojun Liao 已提交
41 42 43
#define GET_HASH_NODE_KEY(_n)  ((char*)(_n) + sizeof(SHashNode))
#define GET_HASH_NODE_DATA(_n) ((char*)(_n) + sizeof(SHashNode) + (_n)->keyLen)

H
Haojun Liao 已提交
44 45
typedef enum SHashLockTypeE {
  HASH_NO_LOCK     = 0,
H
Haojun Liao 已提交
46
  HASH_ENTRY_LOCK  = 1,
H
Haojun Liao 已提交
47
} SHashLockTypeE;
H
hjxilinx 已提交
48

H
Haojun Liao 已提交
49 50 51
typedef struct SHashEntry {
  int32_t    num;      // number of elements in current entry
  SRWLatch   latch;    // entry latch
H
Haojun Liao 已提交
52
  SHashNode *next;
H
Haojun Liao 已提交
53 54 55 56 57 58 59 60 61
} SHashEntry;

typedef struct SHashObj {
  SHashEntry    **hashList;
  size_t          capacity;     // number of slots
  size_t          size;         // number of elements in hash table
  _hash_fn_t      hashFp;       // hash function
  _hash_free_fn_t freeFp;       // hash node free callback function

H
Haojun Liao 已提交
62 63
  SRWLatch        lock;         // read-write spin lock
  SHashLockTypeE  type;         // lock type
H
Haojun Liao 已提交
64 65
  bool            enableUpdate; // enable update
  SArray         *pMemBlock;    // memory block allocated for SHashEntry
H
hjxilinx 已提交
66
} SHashObj;
67

H
hjxilinx 已提交
68
typedef struct SHashMutableIterator {
H
Haojun Liao 已提交
69
  SHashObj  *pHashObj;
H
hjxilinx 已提交
70 71
  int32_t    entryIndex;
  SHashNode *pCur;
H
Haojun Liao 已提交
72 73 74
  SHashNode *pNext;           // current node can be deleted for mutable iterator, so keep the next one before return current
  size_t     numOfChecked;    // already check number of elements in hash table
  size_t     numOfEntries;    // number of entries while the iterator is created
H
hjxilinx 已提交
75 76
} SHashMutableIterator;

H
hjxilinx 已提交
77 78 79 80 81 82 83 84
/**
 * init the hash table
 *
 * @param capacity    initial capacity of the hash table
 * @param fn          hash function to generate the hash value
 * @param threadsafe  thread safe or not
 * @return
 */
H
Haojun Liao 已提交
85
SHashObj *taosHashInit(size_t capacity, _hash_fn_t fn, bool update, SHashLockTypeE type);
86

H
hjxilinx 已提交
87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
/**
 * return the size of hash table
 * @param pHashObj
 * @return
 */
size_t taosHashGetSize(const SHashObj *pHashObj);

/**
 * put element into hash table, if the element with the same key exists, update it
 * @param pHashObj
 * @param key
 * @param keyLen
 * @param data
 * @param size
 * @return
 */
H
hjLiao 已提交
103
int32_t taosHashPut(SHashObj *pHashObj, const void *key, size_t keyLen, void *data, size_t size);
104

H
hjxilinx 已提交
105 106 107 108 109 110 111 112
/**
 * return the payload data with the specified key
 *
 * @param pHashObj
 * @param key
 * @param keyLen
 * @return
 */
H
hjLiao 已提交
113
void *taosHashGet(SHashObj *pHashObj, const void *key, size_t keyLen);
114

H
Haojun Liao 已提交
115 116 117 118 119 120 121 122 123 124 125
/**
 * apply the udf before return the result
 * @param pHashObj
 * @param key
 * @param keyLen
 * @param fp
 * @param d
 * @param dsize
 * @return
 */
void* taosHashGetCB(SHashObj *pHashObj, const void *key, size_t keyLen, void (*fp)(void *), void* d, size_t dsize);
H
Haojun Liao 已提交
126

H
hjxilinx 已提交
127 128 129 130 131 132
/**
 * remove item with the specified key
 * @param pHashObj
 * @param key
 * @param keyLen
 */
H
Haojun Liao 已提交
133
int32_t taosHashRemove(SHashObj *pHashObj, const void *key, size_t keyLen);
134

H
Haojun Liao 已提交
135
int32_t taosHashRemoveWithData(SHashObj *pHashObj, const void *key, size_t keyLen, void* data, size_t dsize);
H
Haojun Liao 已提交
136

H
Haojun Liao 已提交
137
int32_t taosHashCondTraverse(SHashObj *pHashObj, bool (*fp)(void *, void *), void *param);
H
Haojun Liao 已提交
138

H
hjxilinx 已提交
139 140 141 142 143
/**
 * clean up hash table
 * @param handle
 */
void taosHashCleanup(SHashObj *pHashObj);
144

H
hjxilinx 已提交
145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172
/**
 *
 * @param pHashObj
 * @return
 */
SHashMutableIterator* taosHashCreateIter(SHashObj *pHashObj);

/**
 *
 * @param iter
 * @return
 */
bool taosHashIterNext(SHashMutableIterator *iter);

/**
 *
 * @param iter
 * @return
 */
void *taosHashIterGet(SHashMutableIterator *iter);

/**
 *
 * @param iter
 * @return
 */
void* taosHashDestroyIter(SHashMutableIterator* iter);

H
hjxilinx 已提交
173 174 175 176 177 178
/**
 *
 * @param pHashObj
 * @return
 */
int32_t taosHashGetMaxOverflowLinkLength(const SHashObj *pHashObj);
179

H
Haojun Liao 已提交
180 181
size_t taosHashGetMemSize(const SHashObj *pHashObj);

H
hjxilinx 已提交
182 183 184
#ifdef __cplusplus
}
#endif
185 186

#endif  // TDENGINE_HASH_H