std::vector 初始化的模板参数

时间:2020-12-26 15:59:22

标签: c++ c++11 templates initialization

有一个名为 Matrix 的结构,带有模板参数 Ndata_ 字段:

#include <cstddef>
#include <vector>

template <std::size_t N>
struct Matrix {
    std::vector<std::vector<int>> data_{N, std::vector<int>(N)};
};

为什么不能使用圆括号初始化 data_

std::vector<std::vector<int>> data_(N, std::vector<int>(N));

错误如下:

<source>:6:41: error: unknown type name 'N'
    std::vector<std::vector<int>> data_(N, std::vector<int>(N));
                                        ^
<source>:6:61: error: declaration of 'N' shadows template parameter
    std::vector<std::vector<int>> data_(N, std::vector<int>(N));
                                                            ^
<source>:4:23: note: template parameter is declared here
template <std::size_t N>

2 个答案:

答案 0 :(得分:4)

Default member initializer(C++11 起)不支持括号初始化器,但只支持花括号初始化器和等号初始化器。

<块引用>

通过一个默认成员初始值设定项,它是包含在成员声明中的大括号或等于 initializer 并且在构造函数的成员初始值设定项列表中省略该成员时使用。< /p>

除了你展示的那个支撑的,你还可以

template <std::size_t N>
struct Matrix {
    std::vector<std::vector<int>> data_ = std::vector<std::vector<int>>(N, std::vector<int>(N));
};

答案 1 :(得分:4)

() 的正则声明有问题,最烦人的解析。

为了避免这种可能的问题,在类成员初始化中不允许使用这种语法。