如何在 C++ 中声明自定义类型的成员对象并随后进行初始化?

How do I declare a member object of custom type and initialize afterwards in C++?

以下代码在 运行 at cpp.sh 时有效:

#include <iostream>

class B{
    public:
        B(int i);
        int i;
};

B::B(int i) {
    this->i = i;
}

class A{
    public:
        A(B *b);
        B *b;
};

A::A(B *b) {
    this->b = b;
}


int main()
{
  B b(8);
  A a(&b);
  std::cout << a.b->i;
}

它创建了一个B类型的对象,并在A类型的对象中存储了一个指针。 我想要做的是仅传递整数(在本例中为 8)并创建完整对象并将其存储在 a 中而不创建中间对象。

但是当我尝试在 A 中声明 B 类型的对象(不仅仅是指针)时,我得到一个 no matching function for call to 'B::B() 错误。

这是我试过的方法,但不起作用:

#include <iostream>
// B i not changed
class B{
    public:
        B(int i);
        int i;
};

B::B(int i) {
    this->i = i;
}

class A{
    public:
        A(int i);
        B b;
};

A::A(int i) {
    this->b(i); //initialize
}


int main()
{
  A a(8);
  std::cout << a.b->i;
}

为什么在声明 B b; 变量而不是指针 B *b; 时出现 "no matching function" 错误? 我的方法 this->b(i); 在声明后初始化成员是否正确?

您的 class B 不提供不带参数的构造函数(一旦声明任何其他构造函数,隐式定义的默认构造函数就会被删除)。 当你用class B类型的数据成员定义另一个classA时,系统不能初始化这个数据成员,除非你显式定义B的哪个构造函数应该有哪些参数使用过。

你可以通过...克服这个问题

  1. A的构造函数的成员初始化器列表中调用b的构造函数,即A::A(int i) : b(i) {}

  2. 默认-定义数据成员b时初始化,即在A中写入B b = B(1);

  3. B 中定义一个(用户定义的)默认构造函数,例如B() : i(0) {}

  4. B 的(唯一)构造函数中定义默认值,例如B(int i=0)

我更喜欢选项 1;列出选项 2..4 只是为了完整性。

请注意,构造函数主体中的任何代码,无论是哪一个,都不会被视为 "data member initialization"。