std::list 的推导指引

来自cppreference.com
< cpp‎ | container‎ | list

 
 
 
 
在标头 <list> 定义
template< class InputIt,

          class Alloc = std::allocator<
              typename std::iterator_traits<InputIt>::value_type> >
list( InputIt, InputIt, Alloc = Alloc() )

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

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

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

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

注解

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

示例

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