![](/img/trans.png)
[英]Class Composition Constructor d Must Explicitly initialize the reference member
[英]C++ class: must explicitly initialize the member
所以,我把这个 class 称为“网格”。 我还有一个名为“Field”的 class。 Field 类有 4 个 Grid 类型的变量,它们都在构造函数中设置。 除了,他们不是......或者至少编译器不这么认为。
我真的不明白为什么,我将所有变量设置为一个新实例。
当我在红色下划线(在构造函数下)上的 hover 上显示:“'Field' 的构造函数必须显式初始化没有默认构造函数的成员 'b_attack'”
代码:
class Grid{
friend class Field;
private:
unsigned int xSize;
unsigned int ySize;
bool *ptrfield;
Grid(unsigned int xSize, unsigned int ySize){
this->xSize = xSize;
this->ySize = ySize;
ptrfield = new bool[xSize*ySize];
}
};
class Field{
private:
Grid a_own;
Grid a_attack;
Grid b_own;
Grid b_attack;
public:
Field(unsigned int xSize, unsigned int ySize){
a_own = Grid(xSize, ySize);
a_attack = Grid(xSize, ySize);
b_own = Grid(xSize, ySize);
b_attack = Grid(xSize, ySize);
}
void print(){
std::cout << "aHELLO" << std::flush;
std::cout << a_own.xSize << std::flush;
}
};
问题是在输入Field
构造函数的主体之前创建了 4 个Grid
成员对象(或者至少,编译器想要生成代码来创建它们 - 但它不能); 看到这个cppreference (加粗我的):
在构造函数的 forms 和 function 主体的复合语句开始执行之前,所有直接基、虚拟基和非静态数据成员的初始化已完成。 成员初始化器列表是可以指定这些对象的非默认初始化的地方。 对于不能默认初始化的成员,例如引用和 const 限定类型的成员,必须指定成员初始化器。 对于没有成员初始化程序的匿名联合或变体成员不执行初始化。
从这个引用(关于“不能默认初始化的成员”的注释),我们可以看到我们可以在初始化列表中提供所需的初始化; this 放置在构造函数声明的)
结束之后,使用:
后跟所需的逗号分隔的初始值设定项。 像这样,在你的情况下:
Field(unsigned int xSize, unsigned int ySize) : // The ":" starts our initializer list
a_own(xSize, ySize), // .. and each one of these constructs a "Grid"
a_attack(xSize, ySize),
b_own{ xSize, ySize }, // This "{...}" form is newer and many prefer it,
b_attack{ xSize, ySize } // but it can also be a bit confusing
{
return; // We now have nothing left to do in the actual "body" of the c'tor!
}
请随时要求进一步澄清和/或解释。
PS:对于您发布的代码,我的编译器给出了您为所有四个Grid
成员报告的错误; 也许你的“放弃”在第一个之后?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.