C++ 11向量的向量初始化

boy*_*ang 2 vector matrix c++11

在C++ 11中,{}首选()变量初始化.但是,我注意到{}无法正确初始化矢量矢量.

考虑下面的代码,vector<vector<int>> mat2(rows, vector<int>(cols, 2))vector<vector<int>> mat4{rows, vector<int>(cols, 4)}如预期工作,但vector<vector<int>> mat1{rows, vector<int>{cols, 1}}vector<vector<int>> mat3(rows, vector<int>{cols, 3})没有.谁能解释为什么?

#include <iostream>
#include <iomanip>
#include <sstream>
#include <string>
#include <vector>

using namespace std;

string parse_matrix(const vector<vector<int>>& mat)
{
    stringstream ss;
    for (const auto& row : mat) {
        for (const auto& num : row)
            ss << std::setw(3) << num;
        ss << endl;
    }
    return ss.str();
}

int main()
{
    const int rows = 5;
    const int cols = 4;
    vector<vector<int>> mat1{rows, vector<int>{cols, 1}};
    vector<vector<int>> mat2(rows, vector<int>(cols, 2));
    vector<vector<int>> mat3(rows, vector<int>{cols, 3});
    vector<vector<int>> mat4{rows, vector<int>(cols, 4)};

    cout << "mat1:\n" << parse_matrix(mat1);
    cout << "mat2:\n" << parse_matrix(mat2);
    cout << "mat3:\n" << parse_matrix(mat3);
    cout << "mat4:\n" << parse_matrix(mat4);
}
Run Code Online (Sandbox Code Playgroud)

输出:

$ g++ -Wall -std=c++14 -o vector_test2 vector_test2.cc 
$ ./vector_test2
mat1:
  4  1
  4  1
  4  1
  4  1
  4  1
mat2:
  2  2  2  2
  2  2  2  2
  2  2  2  2
  2  2  2  2
  2  2  2  2
mat3:
  4  3
  4  3
  4  3
  4  3
  4  3
mat4:
  4  4  4  4
  4  4  4  4
  4  4  4  4
  4  4  4  4
  4  4  4  4
Run Code Online (Sandbox Code Playgroud)

Igo*_*nik 5

由于多种原因,统一初始化是一种破坏std::vector<int>(更一般地说,算术类型的向量).统一初始化使用与列表初始化相同的语法(构造自initializer_list); 当语法不明确时,构造函数initializer_list优先.

因此,std::vector<int> v(42);意味着"使用std::vector(size_t)构造函数创建42个零的向量"; while std::vector<int> v{42};表示"使用std::vector(std::initializer_list)构造函数创建具有值为42的单个元素的向量".

同样,std::vector<int> v(5, 10);使用双参数构造函数创建一个包含5个元素的向量,所有元素的值均为10; 而std::vector<int> v{5, 10};用途initializer_list-taking构造并创建了两个元素的向量,值5和10.