deduction guides for
std::unordered_map
|
Определено в заголовочном файле
<unordered_map>
|
||
|
template
<
class
InputIt,
class
Hash
=
std::
hash
<
/*тип-ключа-итератора*/
<
InputIt
>>
,
|
(1) | (начиная с C++17) |
|
template
<
class
Key,
class
T,
class
Hash
=
std::
hash
<
Key
>
,
class
Pred
=
std::
equal_to
<
Key
>
,
|
(2) | (начиная с C++17) |
|
template
<
class
InputIt,
class
Alloc
>
unordered_map
(
InputIt, InputIt,
typename
/* см. ниже */
::
size_type
, Alloc
)
|
(3) | (начиная с C++17) |
|
template
<
class
InputIt,
class
Alloc
>
unordered_map
(
InputIt, InputIt, Alloc
)
|
(4) | (начиная с C++17) |
|
template
<
class
InputIt,
class
Hash,
class
Alloc
>
unordered_map
(
InputIt, InputIt,
typename
/* см. ниже */
::
size_type
, Hash,
|
(5) | (начиная с C++17) |
|
template
<
class
Key,
class
T,
typename
Alloc
>
unordered_map
(
std::
initializer_list
<
std::
pair
<
Key, T
>>
,
|
(6) | (начиная с C++17) |
|
template
<
class
Key,
class
T,
typename
Alloc
>
unordered_map
(
std::
initializer_list
<
std::
pair
<
Key, T
>>
, Alloc
)
|
(7) | (начиная с C++17) |
|
template
<
class
Key,
class
T,
class
Hash,
class
Alloc
>
unordered_map
(
std::
initializer_list
<
std::
pair
<
Key, T
>>
,
|
(8) | (начиная с C++17) |
|
template
<
ranges::
input_range
R,
class
Hash
=
std::
hash
<
/*range-key-t*/
<
R
>>
,
|
(9) | (начиная с C++23) |
|
template
<
ranges::
input_range
R,
class
Alloc
>
unordered_map
(
std::
from_range_t
, R
&&
,
|
(10) | (начиная с C++23) |
|
template
<
ranges::
input_range
R,
class
Alloc
>
unordered_map
(
std::
from_range_t
, R
&&
, Alloc
)
|
(11) | (начиная с C++23) |
|
template
<
ranges::
input_range
R,
class
Hash,
class
Alloc
>
unordered_map
(
std::
from_range_t
, R
&&
,
typename
/* см. ниже */
::
size_type
,
|
(12) | (начиная с C++23) |
|
Экспозиционные псевдонимы типов
|
||
|
template
<
class
InputIt
>
using
/*iter-val-t*/
=
|
( только для демонстрации* ) | |
|
template
<
class
InputIt
>
using
/*iter-key-t*/
=
|
( только для демонстрации* ) | |
|
template
<
class
InputIt
>
using
/*iter-mapped-t*/
=
|
( только для демонстрации* ) | |
|
template
<
class
InputIt
>
using
/*iter-to-alloc-t*/
=
|
( только для демонстрации* ) | |
|
template
<
ranges::
input_range
Range
>
using
/*range-key-t*/
=
|
(начиная с C++23)
( только для демонстрации* ) |
|
|
template
<
ranges::
input_range
Range
>
using
/*range-mapped-t*/
=
|
(начиная с C++23)
( только для демонстрации* ) |
|
|
template
<
ranges::
input_range
Range
>
using
/*range-to-alloc-t*/
=
|
(начиная с C++23)
( только для демонстрации* ) |
|
unordered_map
чтобы позволить выведение из диапазона итераторов (перегрузки
(1,3-5)
) и
std::initializer_list
(перегрузки
(2,6-8)
).
unordered_map
чтобы позволить вывод из тега
std::from_range_t
и
input_range
.
Эти перегрузки участвуют в разрешении перегрузки только если
InputIt
удовлетворяет требованиям
LegacyInputIterator
,
Alloc
удовлетворяет требованиям
Allocator
, ни
Hash
ни
Pred
не удовлетворяют требованиям
Allocator
, и
Hash
не является целочисленным типом.
Примечание: степень, в которой библиотека определяет, что тип не удовлетворяет требованиям
LegacyInputIterator
, не специфицирована, за исключением того, что как минимум целочисленные типы не квалифицируются как итераторы ввода. Аналогично, степень, в которой она определяет, что тип не удовлетворяет требованиям
Allocator
, не специфицирована, за исключением того, что как минимум тип-член
Alloc::value_type
должен существовать и выражение
std::
declval
<
Alloc
&
>
(
)
.
allocate
(
std::
size_t
{
}
)
должно быть корректным при рассмотрении как невычисляемый операнд.
Параметр типа
size_type
в этих руководствах относится к члену типа
size_type
типа, выведенного руководством по выводу.
Примечания
| Feature-test macro | Value | Std | Feature |
|---|---|---|---|
__cpp_lib_containers_ranges
|
202202L
|
(C++23) | Ranges-aware construction and insertion; overloads ( 9-12 ) |
Пример
#include <unordered_map> int main() { // std::unordered_map m1 = {{"foo", 1}, {"bar", 2}}; // Ошибка: список инициализации в фигурных скобках не имеет типа: // невозможно вывести pair<Key, T> из {"foo", 1} или {"bar", 2} std::unordered_map m1 = {std::pair{"foo", 2}, {"bar", 3}}; // руководство #2 std::unordered_map m2(m1.begin(), m1.end()); // руководство #1 }
Отчеты о дефектах
Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Применяется к | Поведение в опубликованной версии | Корректное поведение |
|---|---|---|---|
| LWG 3025 | C++17 | руководства по выводу для initializer-list ( 2 ) и ( 6-8 ) используют std:: pair < const Key, T > | используют std:: pair < Key, T > |