std::deque 的推导指引

来自cppreference.com
< cpp‎ | container‎ | deque
 
 
 
 
在标头 <deque> 定义
template<class InputIt,

          class Alloc =std::allocator<
              typenamestd::iterator_traits<InputIt>::value_type>>
deque( InputIt, InputIt, Alloc = Alloc())

    -> deque<typenamestd::iterator_traits<InputIt>::value_type, Alloc>;
(1) (C++17 起)
template<ranges::input_range R,

          class Alloc =std::allocator<ranges::range_value_t<R>>>
deque(std::from_range_t, R&&, Alloc = Alloc())

    -> deque<ranges::range_value_t<R>, Alloc>;
(2) (C++23 起)
1) 为 deque 提供了此推导指引,以允许从迭代器范围推导。此重载只有在InputIt 满足老式输入迭代器(LegacyInputIterator) Alloc 满足分配器(Allocator) 时才会参与重载决议。
2) 为 deque 提供了此推导指引,以允许从 std::from_range_t 标签和一个 input_range 推导。

注意:库确定类型是否满足老式输入迭代器(LegacyInputIterator) 的程度是未指定的,但最低要求是整数类型不具备输入迭代器的条件。类似地,确定类型是否满足分配器(Allocator) 是未指定的,但最低要求是成员类型 Alloc::value_type 必须存在,且表达式 std::declval<Alloc&>().allocate(std::size_t{}) 在作为不求值操作数时必须为良构。

[编辑]注解

功能特性测试标准功能特性
__cpp_lib_containers_ranges202202L(C++23)按范围构造和插入; 重载 (2)

[编辑]示例

#include <deque>#include <vector>   int main(){std::vector<int> v ={1, 2, 3, 4};   // 使用显式推导指引推导 std::deque<int>std::deque x(v.begin(), v.end());   // 推导 std::deque<std::vector<int>::iterator>// 列表初始化的重载决议第一阶段选择从 initializer_list 构造函数合成的候选// 不进行第二阶段且推导指引无效果std::deque y{v.begin(), v.end()};}
close