std::forward_list
的推导指引
来自cppreference.com
< cpp | container | forward list
容器库
std::forward_list
成员函数 | ||||
元素访问 | ||||
迭代器 | ||||
容量 | ||||
修改器 | ||||
操作 | ||||
非成员函数 | ||||
(C++20)(C++20)
|
||||
(C++20
前)(C++20
前)(C++20
前)(C++20
前)(C++20
前)(C++20)
|
||||
推导指引(C++17) |
在标头
<forward_list>
定义
|
||
template< class InputIt,
class Alloc = std::allocator<typename std::iterator_traits<InputIt>::value_type>> |
(C++17 起) | |
为 forward_list 提供此推导指引,以允许从迭代器范围推导。此重载只有在InputIt
满足老式输入迭代器 (LegacyInputIterator)
且 Alloc
满足分配器 (Allocator)
时才会参与重载决议
注意:库确定类型是否满足老式输入迭代器 (LegacyInputIterator)
的程度是未指定的,除了最低要求是整数类型不具备输入迭代器的条件。类似地,确定类型是否满足分配器 (Allocator)
是未指定的,除了最低要求是成员类型 Alloc::value_type
必须存在,且表达式 std::declval<Alloc&>().allocate(std::size_t{}) 在作为不求值操作数时必须为良构。
示例
运行此代码
#include <forward_list> #include <vector> int main() { std::vector<int> v = {1, 2, 3, 4}; // 使用显式推导指引推导 std::forward_list<int> std::forward_list x(v.begin(), v.end()); // 推导 std::forward_list<std::vector<int>::iterator> // 列表初始化的重载决议第一阶段选择从 initializer_list 构造函数合成的候选 // 不进行第二阶段且推导指引无效果 std::forward_list y{v.begin(), v.end()}; }