deduction guides for
std::unordered_multiset
|
Definiert im Header
<unordered_set>
|
||
|
template
<
class
InputIt,
|
(1) | (seit C++17) |
|
template
<
class
T,
class
Hash
=
std::
hash
<
T
>
,
|
(2) | (seit C++17) |
|
template
<
class
InputIt,
class
Alloc
>
unordered_multiset
(
InputIt, InputIt,
typename
/* siehe unten */
::
size_type
, Alloc
)
|
(3) | (seit C++17) |
|
template
<
class
InputIt,
class
Hash,
class
Alloc
>
unordered_multiset
(
InputIt, InputIt,
typename
/* siehe unten */
::
size_type
, Hash, Alloc
)
|
(4) | (seit C++17) |
|
template
<
class
T,
class
Alloc
>
unordered_multiset
(
std::
initializer_list
<
T
>
,
typename
/* siehe unten */
::
size_type
, Alloc
)
|
(5) | (seit C++17) |
|
template
<
class
T,
class
Hash,
class
Alloc
>
unordered_multiset
(
std::
initializer_list
<
T
>
,
typename
/* siehe unten */
::
size_type
,
|
(6) | (seit C++17) |
|
template
<
ranges::
input_range
R,
class
Hash
=
std::
hash
<
ranges::
range_value_t
<
R
>>
,
|
(7) | (seit C++23) |
|
template
<
ranges::
input_range
R,
class
Alloc
>
unordered_multiset
(
std::
from_range_t
, R
&&
,
|
(8) | (seit C++23) |
|
template
<
ranges::
input_range
R,
class
Alloc
>
unordered_multiset
(
std::
from_range_t
, R
&&
, Alloc
)
|
(9) | (seit C++23) |
|
template
<
ranges::
input_range
R,
class
Hash,
class
Alloc
>
unordered_multiset
(
std::
from_range_t
, R
&&
,
|
(10) | (seit C++23) |
unordered_multiset
bereitgestellt, um die Ableitung aus einem Iteratorbereich (Overloads
(1,3,4)
) und
std::initializer_list
(Overloads
(2,5,6)
) zu ermöglichen. Diese Überladung nimmt nur an der Überladungsauflösung teil, wenn
InputIt
die Anforderungen
LegacyInputIterator
erfüllt,
Alloc
die Anforderungen
Allocator
erfüllt, weder
Hash
noch
Pred
die Anforderungen
Allocator
erfüllen und
Hash
kein integraler Typ ist.
unordered_multiset
bereitgestellt, um die Ableitung von einem
std::from_range_t
-Tag und einem
input_range
zu ermöglichen.
Hinweis: Das Ausmaß, in dem die Bibliothek feststellt, dass ein Typ nicht
LegacyInputIterator
erfüllt, ist nicht spezifiziert, außer dass mindestens integrale Typen nicht als Input-Iteratoren qualifizieren. Ebenso ist das Ausmaß, in dem sie feststellt, dass ein Typ nicht
Allocator
erfüllt, nicht spezifiziert, außer dass mindestens der Member-Typ
Alloc::value_type
existieren muss und der Ausdruck
std::
declval
<
Alloc
&
>
(
)
.
allocate
(
std::
size_t
{
}
)
wohlgeformt sein muss, wenn er als nicht ausgewerteter Operand behandelt wird.
Der size_type -Parametertyp in diesen Guides bezieht sich auf den size_type -Membertyp des durch den Deduction Guide abgeleiteten Typs.
Hinweise
| Feature-Test Makro | Wert | Std | Feature |
|---|---|---|---|
__cpp_lib_containers_ranges
|
202202L
|
(C++23) | Ranges-basierte Konstruktion und Einfügung; Überladungen (7-10) |
Beispiel
#include <unordered_set> int main() { // Leitfaden #2 leitet std::unordered_multiset<int> ab std::unordered_multiset s = {1, 2, 3, 4}; // Leitfaden #1 leitet std::unordered_multiset<int> ab std::unordered_multiset s2(s.begin(), s.end()); }