blob: 0810ec3c9c69bbf5c508879143653f2ee0708b01 (
plain) (
blame)
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
|
#pragma once
#include "farm_hash.h"
#include "public.h"
#include <library/cpp/yt/small_containers/compact_vector.h>
#include <util/system/types.h>
#include <atomic>
#include <vector>
namespace NYT {
////////////////////////////////////////////////////////////////////////////////
class TLinearProbeHashTable
{
public:
// 64-bit hash table entry contains 16-bit stamp and 48-bit value.
using TStamp = ui16;
using TValue = ui64;
using TEntry = ui64;
explicit TLinearProbeHashTable(size_t maxElementCount);
bool Insert(TFingerprint fingerprint, TValue value);
template <size_t N>
void Find(TFingerprint fingerprint, TCompactVector<TValue, N>* result) const;
size_t GetByteSize() const;
private:
constexpr static int HashTableExpansionParameter = 2;
constexpr static int ValueLog = 48;
std::vector<std::atomic<TEntry>> HashTable_;
bool DoInsert(ui64 index, TStamp stamp, TValue value);
template <size_t N>
void DoFind(ui64 index, TStamp stamp, TCompactVector<TValue, N>* result) const;
static TStamp StampFromEntry(TEntry entry);
static TValue ValueFromEntry(TEntry entry);
static TEntry MakeEntry(TStamp stamp, TValue value);
static ui64 IndexFromFingerprint(TFingerprint fingerprint);
static TStamp StampFromFingerprint(TFingerprint fingerprint);
};
////////////////////////////////////////////////////////////////////////////////
} // namespace NYT
#define LINEAR_PROBE_INL_H_
#include "linear_probe-inl.h"
#undef LINEAR_PROBE_INL_H_
|