问题描述
有一个名为 Matrix
的结构,带有模板参数 N
和 data_
字段:
#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>
解决方法
Default member initializer(C++11 起)不支持括号初始化器,但只支持花括号初始化器和等号初始化器。
通过一个默认成员初始值设定项,它是包含在成员声明中的大括号或等于 initializer 并且在构造函数的成员初始值设定项列表中省略该成员时使用。
除了你展示的那个支撑的,你还可以
template <std::size_t N>
struct Matrix {
std::vector<std::vector<int>> data_ = std::vector<std::vector<int>>(N,std::vector<int>(N));
};
,
()
的正则声明有问题,最烦人的解析。
为了避免这种可能的问题,在类成员初始化中不允许使用这种语法。