|
| | sparse_set () |
| |
| | sparse_set (size_type bucket_count, const Hash &hash=Hash(), const KeyEqual &equal=KeyEqual(), const Allocator &alloc=Allocator()) |
| |
| | sparse_set (size_type bucket_count, const Allocator &alloc) |
| |
| | sparse_set (size_type bucket_count, const Hash &hash, const Allocator &alloc) |
| |
| | sparse_set (const Allocator &alloc) |
| |
| template<class InputIt > |
| | sparse_set (InputIt first, InputIt last, size_type bucket_count=ht::DEFAULT_INIT_BUCKETS_SIZE, const Hash &hash=Hash(), const KeyEqual &equal=KeyEqual(), const Allocator &alloc=Allocator()) |
| |
| template<class InputIt > |
| | sparse_set (InputIt first, InputIt last, size_type bucket_count, const Allocator &alloc) |
| |
| template<class InputIt > |
| | sparse_set (InputIt first, InputIt last, size_type bucket_count, const Hash &hash, const Allocator &alloc) |
| |
| | sparse_set (std::initializer_list< value_type > init, size_type bucket_count=ht::DEFAULT_INIT_BUCKETS_SIZE, const Hash &hash=Hash(), const KeyEqual &equal=KeyEqual(), const Allocator &alloc=Allocator()) |
| |
| | sparse_set (std::initializer_list< value_type > init, size_type bucket_count, const Allocator &alloc) |
| |
| | sparse_set (std::initializer_list< value_type > init, size_type bucket_count, const Hash &hash, const Allocator &alloc) |
| |
| sparse_set & | operator= (std::initializer_list< value_type > ilist) |
| |
| allocator_type | get_allocator () const |
| |
| iterator | begin () noexcept |
| |
| const_iterator | begin () const noexcept |
| |
| const_iterator | cbegin () const noexcept |
| |
| iterator | end () noexcept |
| |
| const_iterator | end () const noexcept |
| |
| const_iterator | cend () const noexcept |
| |
| bool | empty () const noexcept |
| |
| size_type | size () const noexcept |
| |
| size_type | max_size () const noexcept |
| |
| void | clear () noexcept |
| |
| std::pair< iterator, bool > | insert (const value_type &value) |
| |
| std::pair< iterator, bool > | insert (value_type &&value) |
| |
| iterator | insert (const_iterator hint, const value_type &value) |
| |
| iterator | insert (const_iterator hint, value_type &&value) |
| |
| template<class InputIt > |
| void | insert (InputIt first, InputIt last) |
| |
| void | insert (std::initializer_list< value_type > ilist) |
| |
| template<class... Args> |
| std::pair< iterator, bool > | emplace (Args &&... args) |
| |
| template<class... Args> |
| iterator | emplace_hint (const_iterator hint, Args &&... args) |
| |
| iterator | erase (iterator pos) |
| |
| iterator | erase (const_iterator pos) |
| |
| iterator | erase (const_iterator first, const_iterator last) |
| |
| size_type | erase (const key_type &key) |
| |
| size_type | erase (const key_type &key, std::size_t precalculated_hash) |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| size_type | erase (const K &key) |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| size_type | erase (const K &key, std::size_t precalculated_hash) |
| |
| void | swap (sparse_set &other) |
| |
| size_type | count (const Key &key) const |
| |
| size_type | count (const Key &key, std::size_t precalculated_hash) const |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| size_type | count (const K &key) const |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| size_type | count (const K &key, std::size_t precalculated_hash) const |
| |
| iterator | find (const Key &key) |
| |
| iterator | find (const Key &key, std::size_t precalculated_hash) |
| |
| const_iterator | find (const Key &key) const |
| |
| const_iterator | find (const Key &key, std::size_t precalculated_hash) const |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| iterator | find (const K &key) |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| iterator | find (const K &key, std::size_t precalculated_hash) |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| const_iterator | find (const K &key) const |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| const_iterator | find (const K &key, std::size_t precalculated_hash) const |
| |
| std::pair< iterator, iterator > | equal_range (const Key &key) |
| |
| std::pair< iterator, iterator > | equal_range (const Key &key, std::size_t precalculated_hash) |
| |
| std::pair< const_iterator, const_iterator > | equal_range (const Key &key) const |
| |
| std::pair< const_iterator, const_iterator > | equal_range (const Key &key, std::size_t precalculated_hash) const |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| std::pair< iterator, iterator > | equal_range (const K &key) |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| std::pair< iterator, iterator > | equal_range (const K &key, std::size_t precalculated_hash) |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| std::pair< const_iterator, const_iterator > | equal_range (const K &key) const |
| |
| template<class K , class KE = KeyEqual, typename std::enable_if< has_is_transparent< KE >::value >::type * = nullptr> |
| std::pair< const_iterator, const_iterator > | equal_range (const K &key, std::size_t precalculated_hash) const |
| |
| size_type | bucket_count () const |
| |
| size_type | max_bucket_count () const |
| |
| float | load_factor () const |
| |
| float | max_load_factor () const |
| |
| void | max_load_factor (float ml) |
| |
| void | rehash (size_type count) |
| |
| void | reserve (size_type count) |
| |
| hasher | hash_function () const |
| |
| key_equal | key_eq () const |
| |
| iterator | mutable_iterator (const_iterator pos) |
| |
| template<class Serializer > |
| void | serialize (Serializer &serializer) const |
| |
template<class Key, class Hash = std::hash<Key>, class KeyEqual = std::equal_to<Key>, class Allocator = std::allocator<Key>, class GrowthPolicy = tsl::sh::power_of_two_growth_policy<2>, tsl::sh::exception_safety ExceptionSafety = tsl::sh::exception_safety::basic, tsl::sh::sparsity Sparsity = tsl::sh::sparsity::medium>
class tsl::sparse_set< Key, Hash, KeyEqual, Allocator, GrowthPolicy, ExceptionSafety, Sparsity >
Implementation of a sparse hash set using open-addressing with quadratic probing. The goal on the hash set is to be the most memory efficient possible, even at low load factor, while keeping reasonable performances.
GrowthPolicy defines how the set grows and consequently how a hash value is mapped to a bucket. By default the set uses tsl::sh::power_of_two_growth_policy. This policy keeps the number of buckets to a power of two and uses a mask to map the hash to a bucket instead of the slow modulo. Other growth policies are available and you may define your own growth policy, check tsl::sh::power_of_two_growth_policy for the interface.
ExceptionSafety defines the exception guarantee provided by the class. By default only the basic exception safety is guaranteed which mean that all resources used by the hash set will be freed (no memory leaks) but the hash set may end-up in an undefined state if an exception is thrown (undefined here means that some elements may be missing). This can ONLY happen on rehash (either on insert or if rehash is called explicitly) and will occur if the Allocator can't allocate memory (std::bad_alloc) or if the copy constructor (when a nothrow move constructor is not available) throws an exception. This can be avoided by calling reserve beforehand. This basic guarantee is similar to the one of google::sparse_hash_map and spp::sparse_hash_map. It is possible to ask for the strong exception guarantee with tsl::sh::exception_safety::strong, the drawback is that the set will be slower on rehashes and will also need more memory on rehashes.
Sparsity defines how much the hash set will compromise between insertion speed and memory usage. A high sparsity means less memory usage but longer insertion times, and vice-versa for low sparsity. The default tsl::sh::sparsity::medium sparsity offers a good compromise. It doesn't change the lookup speed.
Key must be nothrow move constructible and/or copy constructible.
If the destructor of Key throws an exception, the behaviour of the class is undefined.
Iterators invalidation:
- clear, operator=, reserve, rehash: always invalidate the iterators.
- insert, emplace, emplace_hint: if there is an effective insert, invalidate the iterators.
- erase: always invalidate the iterators.
template<class Key , class Hash = std::hash<Key>, class KeyEqual = std::equal_to<Key>, class Allocator = std::allocator<Key>, class GrowthPolicy = tsl::sh::power_of_two_growth_policy<2>, tsl::sh::exception_safety ExceptionSafety = tsl::sh::exception_safety::basic, tsl::sh::sparsity Sparsity = tsl::sh::sparsity::medium>
template<class Deserializer >
| static sparse_set tsl::sparse_set< Key, Hash, KeyEqual, Allocator, GrowthPolicy, ExceptionSafety, Sparsity >::deserialize |
( |
Deserializer & |
deserializer, |
|
|
bool |
hash_compatible = false |
|
) |
| |
|
inlinestatic |
Deserialize a previouly serialized set through the deserializer parameter.
The deserializer parameter must be a function object that supports the following calls:
template<typename U> U operator()(); where the types std::uint64_t, float and Key must be supported for U.
If the deserialized hash set type is hash compatible with the serialized set, the deserialization process can be sped up by setting hash_compatible to true. To be hash compatible, the Hash, KeyEqual and GrowthPolicy must behave the same way than the ones used on the serialized set. The std::size_t must also be of the same size as the one on the platform used to serialize the set. If these criteria are not met, the behaviour is undefined with hash_compatible sets to true, .
The behaviour is undefined if the type Key of the sparse_set is not the same as the type used during serialization.
The implementation leaves binary compatibilty (endianness, IEEE 754 for floats, size of int, ...) of the types it deserializes in the hands of the Deserializer function object if compatibilty is required.