std::flat_multiset - cppreference.com (original) (raw)
| | | | | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | ------------- | | template< class Key, class Compare = std::less<Key>, class KeyContainer = std::vector<Key> > class flat_multiset; | | (since C++23) |
The flat multiset is a container adaptor that gives the functionality of an associative container that stores a sorted set of objects of type Key
. Unlike std::flat_set, multiple keys with equivalent values are allowed. Sorting is done using the key comparison function Compare
.
The class template flat_multiset
acts as a wrapper to the underlying sorted container passed as object of type KeyContainer
.
Everywhere the standard library uses the Compare requirements, uniqueness is determined by using the equivalence relation. Informally, two objects a and b are considered equivalent if neither compares less than the other: !comp(a, b) && !comp(b, a).
std::flat_multiset
meets the requirements of Container, ReversibleContainer, optional container requirements, and all requirements of AssociativeContainer (including logarithmic search complexity), except that:
- requirements related to nodes are not applicable,
- iterator invalidation requirements differ,
- the complexity of insertion and erasure operations is linear.
A flat multiset supports most AssociativeContainer's operations that use equal keys.
All member functions of std::flat_multiset are constexpr: it is possible to create and use std::flat_multiset objects in the evaluation of a constant expression.However, std::flat_multiset objects generally cannot be constexpr, because any dynamically allocated storage must be released in the same evaluation of constant expression. | (since C++26) |
---|
Contents
- 1 Iterator invalidation
- 2 Template parameters
- 3 Member types
- 4 Member objects
- 5 Member functions
- 6 Non-member functions
- 7 Helper classes
- 8 Tags
- 9 Deduction guides
- 10 Notes
- 11 Example
- 12 See also
[edit] Iterator invalidation
[edit] Template parameters
[edit] Member types
Type | Definition |
---|---|
container_type | KeyContainer[edit] |
key_type | Key[edit] |
value_type | Key[edit] |
key_compare | Compare[edit] |
value_compare | Compare[edit] |
reference | value_type&[edit] |
const_reference | const value_type&[edit] |
size_type | typename KeyContainer::size_type[edit] |
difference_type | typename KeyContainer::difference_type[edit] |
iterator | implementation-defined LegacyRandomAccessIterator, ConstexprIterator(since C++26) and random_access_iterator to value_type[edit] |
const_iterator | implementation-defined LegacyRandomAccessIterator, ConstexprIterator(since C++26) and random_access_iterator to const value_type[edit] |
reverse_iterator | std::reverse_iterator<iterator>[edit] |
const_reverse_iterator | std::reverse_iterator<const_iterator>[edit] |
[edit] Member objects
Member | Description |
---|---|
container_type c (private) | the adapted container(exposition-only member object*) |
key_compare compare (private) | the comparison function object(exposition-only member object*) |
[edit] Member functions
(constructor) | constructs the flat_multiset (public member function) [edit] |
---|---|
(destructor)(implicitly declared) | destroys every element of the container adaptor (public member function) |
operator= | assigns values to the container adaptor (public member function) [edit] |
Iterators | |
begincbegin | returns an iterator to the beginning (public member function) [edit] |
endcend | returns an iterator to the end (public member function) [edit] |
rbegincrbegin | returns a reverse iterator to the beginning (public member function) [edit] |
rendcrend | returns a reverse iterator to the end (public member function) [edit] |
Capacity | |
empty | checks whether the container adaptor is empty (public member function) [edit] |
size | returns the number of elements (public member function) [edit] |
max_size | returns the maximum possible number of elements (public member function) [edit] |
Modifiers | |
emplace | constructs element in-place (public member function) [edit] |
emplace_hint | constructs elements in-place using a hint (public member function) [edit] |
insert | inserts elements (public member function) [edit] |
insert_range | inserts a range of elements (public member function) [edit] |
extract | extracts the underlying container (public member function) [edit] |
replace | replaces the underlying container (public member function) [edit] |
erase | erases elements (public member function) [edit] |
swap | swaps the contents (public member function) [edit] |
clear | clears the contents (public member function) [edit] |
Lookup | |
find | finds element with specific key (public member function) [edit] |
count | returns the number of elements matching specific key (public member function) [edit] |
contains | checks if the container contains element with specific key (public member function) [edit] |
lower_bound | returns an iterator to the first element not less than the given key (public member function) [edit] |
upper_bound | returns an iterator to the first element greater than the given key (public member function) [edit] |
equal_range | returns range of elements matching a specific key (public member function) [edit] |
Observers | |
key_comp | returns the function that compares keys (public member function) [edit] |
value_comp | returns the function that compares keys in objects of type value_type (public member function) [edit] |
[edit] Non-member functions
[edit] Helper classes
[edit] Tags
[edit] Deduction guides
[edit] Notes
The member types iterator
and const_iterator
may be aliases to the same type. This means defining a pair of function overloads using the two types as parameter types may violate the One Definition Rule. Since iterator
is convertible to const_iterator
, a single function with a const_iterator
as parameter type will work instead.
Feature-test macro | Value | Std | Feature |
---|---|---|---|
__cpp_lib_flat_set | 202207L | (C++23) | std::flat_set and std::flat_multiset |
__cpp_lib_constexpr_flat_set | 202502L | (C++26) | constexpr std::flat_multiset |
[edit] Example
[edit] See also
| | adapts a container to provide a collection of unique keys, sorted by keys (class template) [edit] | | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | | collection of keys, sorted by keys (class template) [edit] | | | collection of keys, hashed by keys (class template) [edit] |