#include <robin_growth_policy.h>
Public Member Functions | |
std::size_t | bucket_for_hash (std::size_t hash) const noexcept |
void | clear () noexcept |
std::size_t | max_bucket_count () const |
std::size_t | next_bucket_count () const |
power_of_two_growth_policy (std::size_t &min_bucket_count_in_out) | |
Protected Attributes | |
std::size_t | m_mask |
Static Private Member Functions | |
static constexpr bool | is_power_of_two (std::size_t value) |
static std::size_t | round_up_to_power_of_two (std::size_t value) |
Grow the hash table by a factor of GrowthFactor keeping the bucket count to a power of two. It allows the table to use a mask operation instead of a modulo operation to map a hash to a bucket.
GrowthFactor must be a power of two >= 2.
Definition at line 95 of file robin_growth_policy.h.
|
inlineexplicit |
Called on the hash table creation and on rehash. The number of buckets for the table is passed in parameter. This number is a minimum, the policy may update this value with a higher value if needed (but not lower).
If 0 is given, min_bucket_count_in_out must still be 0 after the policy creation and bucket_for_hash must always return 0 in this case.
Definition at line 105 of file robin_growth_policy.h.
|
inlinenoexcept |
Return the bucket [0, bucket_count()) to which the hash belongs. If bucket_count() is 0, it must always return 0.
Definition at line 124 of file robin_growth_policy.h.
|
inlinenoexcept |
Reset the growth policy as if it was created with a bucket count of 0. After a clear, the policy must always return 0 when bucket_for_hash is called.
Definition at line 153 of file robin_growth_policy.h.
|
inlinestaticconstexprprivate |
Definition at line 173 of file robin_growth_policy.h.
|
inline |
Return the maximum number of buckets supported by the policy.
Definition at line 143 of file robin_growth_policy.h.
|
inline |
Return the number of buckets that should be used on next growth.
Definition at line 131 of file robin_growth_policy.h.
|
inlinestaticprivate |
Definition at line 156 of file robin_growth_policy.h.
|
protected |
Definition at line 179 of file robin_growth_policy.h.