std::uses_allocator_construction_args
在标头 <memory> 定义
|
||
T 不是 std::pair 的特化 |
||
template< class T, class Alloc, class... Args > constexpr auto uses_allocator_construction_args( const Alloc& alloc, |
(1) | (C++20 起) |
T 是 std::pair 的特化 |
||
template< class T, class Alloc, class Tuple1, class Tuple2 > constexpr auto uses_allocator_construction_args( const Alloc& alloc, |
(2) | (C++20 起) |
template< class T, class Alloc > constexpr auto uses_allocator_construction_args( const Alloc& alloc ) noexcept; |
(3) | (C++20 起) |
template< class T, class Alloc, class U, class V > constexpr auto uses_allocator_construction_args( const Alloc& alloc, |
(4) | (C++20 起) |
template< class T, class Alloc, class U, class V > constexpr auto uses_allocator_construction_args( const Alloc& alloc, |
(5) | (C++23 起) |
template< class T, class Alloc, class U, class V > constexpr auto uses_allocator_construction_args( const Alloc& alloc, |
(6) | (C++20 起) |
template< class T, class Alloc, class U, class V > constexpr auto uses_allocator_construction_args( const Alloc& alloc, |
(7) | (C++20 起) |
template< class T, class Alloc, class U, class V > constexpr auto uses_allocator_construction_args( const Alloc& alloc, |
(8) | (C++23 起) |
template< class T, class Alloc, class NonPair > constexpr auto uses_allocator_construction_args( const Alloc& alloc, |
(9) | (C++20 起) |
准备好以使用分配器构造的方式创建给定类型 T
对象所需的实参列表。
T
不是 std::pair 的特化时才会参与重载决议。返回按下列方式确定的 std::tuple:
- 若 std::uses_allocator_v<T, Alloc> 为 false 且 std::is_constructible_v<T, Args...> 为 true,则返回 std::forward_as_tuple(std::forward<Args>(args)...)。
- 否则,若 std::uses_allocator_v<T, Alloc> 为 true 且 std::is_constructible_v<T, std::allocator_arg_t, const Alloc&, Args...> 为 true,则返回
std::tuple<std::allocator_arg_t, const Alloc&, Args&&...>(std::allocator_arg, alloc,
std::forward<Args>(args)...)。 - 否则,若 std::uses_allocator_v<T, Alloc> 为 true 且 std::is_constructible_v<T, Args..., const Alloc&> 为 true,则返回 std::forward_as_tuple(std::forward<Args>(args)..., alloc)。
- 否则,程序非良构
T
是 std::pair 的特化时才会参与重载决议。对作为 std::pair<T1, T2> 的 T
等价于
return std::make_tuple(std::piecewise_construct, std::apply([&alloc](auto&&... args1) { return std::uses_allocator_construction_args<T1>(alloc, std::forward<decltype(args1)>(args1)...); }, std::forward<Tuple1>(x) ), std::apply([&alloc](auto&&... args2) { return std::uses_allocator_construction_args<T2>(alloc, std::forward<decltype(args2)>(args2)...); }, std::forward<Tuple2>(y) ) );
T
是 std::pair 的特化时才会参与重载决议。等价于
return std::uses_allocator_construction_args<T>(alloc, std::piecewise_construct, std::tuple<>{}, std::tuple<>{} );
T
是 std::pair 的特化时才会参与重载决议。等价于
return std::uses_allocator_construction_args<T>(alloc, std::piecewise_construct, std::forward_as_tuple(std::forward<U>(u)), std::forward_as_tuple(std::forward<V>(v)) );
T
是 std::pair 的特化时才会参与重载决议。等价于
return std::uses_allocator_construction_args<T>(alloc, std::piecewise_construct, std::forward_as_tuple(pr.first), std::forward_as_tuple(pr.second) );
T
是 std::pair 的特化时才会参与重载决议。等价于
return std::uses_allocator_construction_args<T>(alloc, std::piecewise_construct, std::forward_as_tuple(std::get<0>(std::move(pr))), std::forward_as_tuple(std::get<1>(std::move(pr))) );
T
是 std::pair 的特化,并且给定仅用于阐释的函数模板
template<class A, class B> void /*deduce-as-pair*/(const std::pair<A, B>&);
,/*deduce-as-pair*/(non_pair) 在当作不求值操作数时非良构时才会参与重载决议。
令仅用于阐释的类 pair-constructor
定义为
class /*pair-constructor*/ { const Alloc& alloc_; // 仅用于阐释 NonPair& u_; // 仅用于阐释 constexpr reconstruct(const std::remove_cv<T>& p) const // 仅用于阐释 { return std::make_obj_using_allocator<std::remove_cv<T>>(alloc_, p); } constexpr reconstruct(std::remove_cv<T>&& p) const // 仅用于阐释 { return std::make_obj_using_allocator<std::remove_cv<T>>(alloc_, std::move(p)); } public: constexpr operator std::remove_cv<T>() const { return reconstruct(std::forward<NonPair>(u_)); } };
pair_construction
是 pair-constructor
类型的值,其 alloc_
与 u_
成员分别为 alloc
与 non_pair
。参数
alloc | - | 使用的分配器 |
args | - | 传递给 T 构造函数的实参
|
x | - | 传递给 T 的 first 数据成员的构造函数的实参的元组
|
y | - | 传递给 T 的 second 数据成员的构造函数的实参的元组
|
u | - | 传递给 T 的 first 数据成员的构造函数的单个实参
|
v | - | 传递给 T 的 second 数据成员的构造函数的单个实参
|
pr | - | 对偶,其 first 数据成员将被传递给 T 的 first 数据成员的构造函数,而其 second 数据成员将被传递给 T 的 second 数据成员的构造函数
|
non_pair | - | 将被转换成 std::pair 以供进一步构造的单个实参 |
返回值
适合于传递给 T
构造函数的实参的 std::tuple。
注解
重载 (2-9) 提供向 std::pair 中的分配器传播,它们不支持前导分配器或尾随分配器约定(不同于使用前导分配器约定的 std::tuple 等)。
在用于使用分配器构造时,pair-constructor
的转换函数首先将提供的实参转换成 std::pair,然后再以使用分配器构造从该 std::pair 构造其结果。
示例
本节未完成 原因:暂无示例 |
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 3525 | C++20 | 没有重载能处理可转换成 pair 的非 pair 类型
|
添加了重构的重载 |
参阅
(C++11) |
检查指定的类型是否支持使用分配器的构造 (类模板) |
(C++20) |
以使用分配器构造的手段创建给类型的对象 (函数模板) |
以使用分配器构造的手段在指定的内存位置创建给定类型的对象 (函数模板) |