美文网首页c++
C++11:std::initializer_list

C++11:std::initializer_list

作者: 风夜猫 | 来源:发表于2018-06-14 14:26 被阅读0次

基本概念

std::initializer_list<T> 类型对象是一个访问 const T 类型对象数组的轻量代理对象。
vector不同的是,initializer_list对象中的元素永远是常量值,我们无法改变initializer_list对象中元素的值

作用

方便了对于STL的container的初始化
例如:之前初始化一个vector需要这样:

std::vector v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
v.push_back(4);

有了initializer_list后:

std::vector v = { 1, 2, 3, 4 };

原因:vector提供了这样的构造函数

template <typename T>
vector::vector(std::initializer_list<T> initList);

构造

  • 花括号初始化器列表初始化一个对象,其中对应构造函数接受一个 std::initializer_list 参数
std::vector v = { 1, 2, 3, 4 };
  • 花括号初始化器列表为赋值的右运算数,或函数调用参数,而对应的赋值运算符/函数接受 std::initializer_list 参数
void someThing(std::initializer_list<int> items)
{
    someThing(items.begin(), items.end()); 
}
  • 绑定花括号初始化器列表auto,包括在范围for 循环中
std::vector<int> v = { 1, 2 };
auto i = { 1, 2 };

示例

#include <iostream>
#include <vector>
#include <initializer_list>
 
template <class T>
struct S {
    std::vector<T> v;
    S(std::initializer_list<T> l) : v(l) {
         std::cout << "constructed with a " << l.size() << "-element list\n";
    }
    void append(std::initializer_list<T> l) {
        v.insert(v.end(), l.begin(), l.end());
    }
    std::pair<const T*, std::size_t> c_arr() const {
        return {&v[0], v.size()};  // 在 return 语句中复制列表初始化
                                   // 这不使用 std::initializer_list
    }
};
 
template <typename T>
void templated_fn(T) {}
 
int main()
{
    S<int> s = {1, 2, 3, 4, 5}; // 复制初始化
    s.append({6, 7, 8});      // 函数调用中的列表初始化
 
    std::cout << "The vector size is now " << s.c_arr().second << " ints:\n";
 
    for (auto n : s.v)
        std::cout << n << ' ';
    std::cout << '\n';
 
    std::cout << "Range-for over brace-init-list: \n";
 
    for (int x : {-1, -2, -3}) // auto 的规则令此带范围 for 工作
        std::cout << x << ' ';
    std::cout << '\n';
 
    auto al = {10, 11, 12};   // auto 的特殊规则
 
    std::cout << "The list bound to auto has size() = " << al.size() << '\n';
 
//    templated_fn({1, 2, 3}); // 编译错误!“ {1, 2, 3} ”不是表达式,
                             // 它无类型,故 T 无法推导
    templated_fn<std::initializer_list<int>>({1, 2, 3}); // OK
    templated_fn<std::vector<int>>({1, 2, 3});           // 也 OK
}

相关文章

网友评论

    本文标题:C++11:std::initializer_list

    本文链接:https://www.haomeiwen.com/subject/smaeeftx.html