std::flat_set<Key,Compare,KeyContainer>::flat_set - cppreference.com
|
|
(1) | (since C++23) |
|
|
(2) | (since C++23) |
|
|
(3) | (since C++23) |
|
|
(4) | (since C++23) |
|
|
(5) | (since C++23) |
|
|
(6) | (since C++23) |
|
|
(7) | (since C++23) |
|
|
(8) | (since C++23) |
|
|
(9) | (since C++23) |
|
|
(10) | (since C++23) |
|
|
(11) | (since C++23) |
|
|
(12) | (since C++23) |
|
|
(13) | (since C++23) |
|
|
(14) | (since C++23) |
|
|
(15) | (since C++23) |
|
|
(16) | (since C++23) |
|
|
(17) | (since C++23) |
|
|
(18) | (since C++23) |
|
|
(19) | (since C++23) |
|
|
(20) | (since C++23) |
|
|
(21) | (since C++23) |
|
|
(22) | (since C++23) |
|
|
(23) | (since C++23) |
|
|
(24) | (since C++23) |
|
|
(25) | (since C++23) |
|
|
(26) | (since C++23) |
|
|
(27) | (since C++23) |
|
|
(28) | (since C++23) |
Constructs new container adaptor from a variety of data sources and optionally provided comparison function object comp and/or allocator alloc.
1) A default constructor. Constructs an empty container adaptor.
2) A copy constructor. Constructs c with the copy of the contents of other.c and compare with other.compare.
See allocator usage note below.
3) A move constructor. Constructs the container adaptor with the contents of other using move semantics.
See allocator usage note below.
4) Constructs the underlying container with the contents of the container cont. First, initializes c with std::move(cont) and compare with comp. Then sorts the c with respect to comp. Finally, makes elements unique, i.e. erases all but the first element from each group of consecutive equivalent elements.
5) Same as (4), equivalent to flat_set(cont);.
See allocator usage note below.
6) Same as (4), equivalent to flat_set(cont, comp);.
See allocator usage note below.
7) Constructs the underlying container with the contents of the other container cont. Initializes c with std::move(cont) and compare with comp.
8) Same as (7), equivalent to flat_set(s, cont);.
See allocator usage note below.
9) Same as (7), equivalent to flat_set(s, cont, comp);.
See allocator usage note below.
10) Constructs an empty container adaptor.
11,12) Constructs an empty container adaptor. See allocator usage note below.
13) Constructs the container adaptor with the contents of the range [first, last), equivalent to insert(first, last);.
14,15) Same as (13). See allocator usage note below.
16) Constructs the container adaptor with the contents of the range rg. First, uses (10) as delegating constructor. Then initializes c with the contents of rg as if by insert_range(std::forward<R>(rg));.
18,19) Same as (16). See allocator usage note below.
20) Constructs the underlying container with the contents of the range [first, last). Initializes c with c(first, last) and compare with compare(comp).
21,22) Same as (20). See allocator usage note below.
24,25) Same as (23). See allocator usage note below.
27,28) Save as (26). See allocator usage note below.
Note for overloads (13-15,20-22): If [first, last) is not a valid range, the behavior is undefined.
Note for overloads (4-6,13-19,23-25): If multiple elements in the range have keys that compare equivalent, it is unspecified which element is inserted (pending LWG2844).
Allocator usage note
The constructors (2,3,5,6,8,9,11,12,14,15,17,19,21,22,24,25,27,28) are equivalent to the corresponding non-allocator constructors except that c is constructed with uses-allocator construction.
These overloads participate in overload resolution only if std::uses_allocator_v<container_type, Allocator> is true.
Parameters
| cont | - | a container to be used as source to initialize the underlying container |
| other | - | another flat_set to be used as source to initialize the elements of the underlying container with
|
| alloc | - | an allocator to use for all memory allocations of the underlying container |
| comp | - | a function object to be used for all comparisons of keys |
| first, last | - | the pair of iterators defining the source range of elements to copy |
| init | - | an initializer list to initialize the elements of the underlying container with |
| rg | - | a container compatible range (that is, an input_range whose elements are convertible to value_type) to be used as source to initialize the underlying container
|
| fr | - | a disambiguation tag that indicates that the contained member should be range constructed |
| s | - | a disambiguation tag that indicates that the input sequence is sorted with respect to compare and all its elements are unique
|
| Type requirements | ||
-InputIt must meet the requirements of LegacyInputIterator.
| ||
-Compare must meet the requirements of Compare.
| ||
-Allocator must meet the requirements of Allocator.
| ||
Complexity
1) Constant.
2) Linear in size of other.
3) Same as the corresponding move-constructor of the wrapped container, i.e. constant or linear in size of cont.
4-6) Linear in N if cont is sorted with respect to compare, otherwise 𝓞(N·log(N)), where N is the value of cont.size() before this call.
7-9) Same as the corresponding move-constructor of the wrapped container, i.e. constant or linear in size of cont.
10-12) Constant.
13-15) Linear in N if the input range [first, last) is sorted with respect to compare, otherwise 𝓞(N·log(N)), where N is the value of cont.size() before this call.
16-19) Linear in N if the input range rg is sorted with respect to compare, otherwise 𝓞(N·log(N)), where N is the value of cont.size() before this call.
20-22) Linear in size of [first, last).
23-25) Linear in N if the elements of init are sorted with respect to compare, otherwise 𝓞(N·log(N)), where N is the value of cont.size() before this call.
26-28) Linear in size of init.
Exceptions
Calls to Allocator::allocate may throw.
Notes
After container move construction (overload (3,16-19)), references, pointers, and iterators (other than the end iterator) to other remain valid, but refer to elements that are now in *this. The current standard makes this guarantee via the blanket statement in [container.reqmts]/67, and a more direct guarantee is under consideration via LWG issue 2321.
Example
See also
| assigns values to the container adaptor (public member function) [edit] |