std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>:: unordered_multimap
| (1) | ||
|
unordered_multimap
(
)
: unordered_multimap ( size_type ( /* unspecified */ ) ) { } |
(seit C++11)
(bis C++20) |
|
|
unordered_multimap
(
)
;
|
(seit C++20) | |
|
explicit
unordered_multimap
(
size_type bucket_count,
const
Hash
&
hash
=
Hash
(
)
,
|
(2) | (seit C++11) |
|
unordered_multimap
(
size_type bucket_count,
const
Allocator
&
alloc
)
|
(3) | (seit C++14) |
|
unordered_multimap
(
size_type bucket_count,
const
Hash
&
hash,
|
(4) | (seit C++14) |
|
explicit
unordered_multimap
(
const
Allocator
&
alloc
)
;
|
(5) | (seit C++11) |
|
template
<
class
InputIt
>
unordered_multimap
(
InputIt first, InputIt last,
|
(6) | (seit C++11) |
|
template
<
class
InputIt
>
unordered_multimap
(
InputIt first, InputIt last,
|
(7) | (seit C++14) |
|
template
<
class
InputIt
>
unordered_multimap
(
InputIt first, InputIt last,
|
(8) | (seit C++14) |
|
unordered_multimap
(
const
unordered_multimap
&
other
)
;
|
(9) | (seit C++11) |
|
unordered_multimap
(
const
unordered_multimap
&
other,
const
Allocator
&
alloc
)
;
|
(10) | (seit C++11) |
|
unordered_multimap
(
unordered_multimap
&&
other
)
;
|
(11) | (seit C++11) |
|
unordered_multimap
(
unordered_multimap
&&
other,
const
Allocator
&
alloc
)
;
|
(12) | (seit C++11) |
|
unordered_multimap
(
std::
initializer_list
<
value_type
>
init,
size_type bucket_count
=
/* nicht spezifiziert */
,
|
(13) | (seit C++11) |
|
unordered_multimap
(
std::
initializer_list
<
value_type
>
init,
size_type bucket_count,
|
(14) | (seit C++14) |
|
unordered_multimap
(
std::
initializer_list
<
value_type
>
init,
size_type bucket_count,
|
(15) | (seit C++14) |
|
template
<
container-compatible-range
<
value_type
>
R
>
unordered_multimap
(
std::
from_range_t
, R
&&
rg,
|
(16) | (seit C++23) |
|
template
<
container-compatible-range
<
value_type
>
R
>
unordered_multimap
(
std::
from_range_t
, R
&&
rg,
|
(17) | (seit C++23) |
|
template
<
container-compatible-range
<
value_type
>
R
>
unordered_multimap
(
std::
from_range_t
, R
&&
rg,
|
(18) | (seit C++23) |
Konstruiert einen neuen Container aus verschiedenen Datenquellen. Verwendet optional die vom Benutzer bereitgestellte bucket_count als minimale Anzahl zu erstellender Buckets, hash als Hash-Funktion, equal als Funktion zum Vergleichen von Schlüsseln und alloc als Allokator.
[
first
,
last
)
. Setzt
max_load_factor()
auf
1.0
.
|
Der Template-Parameter
|
(seit C++23) |
|
Der Template-Parameter
|
(seit C++23) |
Inhaltsverzeichnis |
Parameter
| alloc | - | Allokator, der für alle Speicherallokationen dieses Containers verwendet wird |
| bucket_count | - | Minimale Anzahl von Buckets, die bei der Initialisierung verwendet werden. Wenn nicht angegeben, wird ein nicht spezifizierter Standardwert verwendet |
| hash | - | Zu verwendende Hash-Funktion |
| equal | - | Vergleichsfunktion, die für alle Schlüsselvergleiche dieses Containers verwendet wird |
| first, last | - | Das Iteratorpaar, das die Quelle range der zu kopierenden Elemente definiert |
| rg | - |
Ein
container compatible range
, also ein
input_range
, dessen Elemente in
value_type
konvertierbar sind
|
| other | - | Ein weiterer Container, der als Quelle zur Initialisierung der Elemente des Containers verwendet wird |
| init | - | Initialisierungsliste zur Initialisierung der Elemente des Containers |
| Typanforderungen | ||
-
InputIt
muss die Anforderungen von
LegacyInputIterator
erfüllen.
|
||
Komplexität
Exceptions
Aufrufe von
Allocator::allocate
können eine Ausnahme werfen.
Hinweise
Obwohl es erst ab C++23 formal erforderlich ist, haben einige Implementierungen den Template-Parameter
Allocator
bereits in früheren Modi in
nicht abgeleitete Kontexte
platziert.
| Feature-Test Makro | Wert | Std | Feature |
|---|---|---|---|
__cpp_lib_containers_ranges
|
202202L
|
(C++23) | Ranges-bewusste Konstruktion und Einfügung; Überladungen ( 16-18 ) |
Beispiel
|
Dieser Abschnitt ist unvollständig
Grund: Kein Beispiel |
Fehlerberichte
Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | Angewendet auf | Verhalten wie veröffentlicht | Korrektes Verhalten |
|---|---|---|---|
| LWG 2193 | C++11 | der Standardkonstruktor ( 1 ) war explicit | als non-explicit festgelegt |
| LWG 2230 | C++11 | die Semantik von Überladung ( 13 ) war nicht spezifiziert | spezifiziert |
Siehe auch
|
weist dem Container Werte zu
(öffentliche Elementfunktion) |