当使用带有C ++ 11的类成员初始化功能的std :: vector&#39的填充构造函数(任一形式)时,以下代码无法编译(在clang / llvm 3.6下):
#include <vector>
class Foo
{
std::vector<char> buf_(10); //compiler error!
std::vector<std::vector<char>> buf2_(10, std::vector<char>(20)); //compiler error!
public:
void Bar();
};
void Foo::Bar()
{
std::vector<char> buf3_(10); //OK
std::vector<std::vector<char>> buf4_(10, std::vector<char>(20)); //OK
}
我已经搜索了有关向量填充构造函数和类成员初始化的问题,但是已经空了。知道我错过了什么吗?
答案 0 :(得分:5)
使用该语法不允许非静态数据成员的就地初始化。你需要表格
T t{args}; // 1
或
T = t{args}; // 2
或
T = t(args); // 3
原因是避免任何看起来像函数声明的东西。
另请注意,std::vector
形式1
可能会导致一些令人惊讶的行为,因为初始化列表构造函数优先。所以
std::vector<int> v{1,2}; // two elements: 1 and 2
与
不同std::vector<int> v = std::vector<int>(1, 2); // 1 element: 2
答案 1 :(得分:2)
知道我错过了什么吗?
有效的语法?不知道你在哪里读到这是有效的。
使用curlies或=
:
struct Foo
{
std::vector<char> buf_ = std::vector<char>(10);
std::vector<std::vector<char>> buf2_{10, std::vector<char>(20)};
};
相关的语法生成是一个大括号或等于初始化,它的名字中有一条线索。 :)