我不明白为什么这段代码显示02002而不是00022。据我所知,构造函数的顺序是:第一个基类,然后是成员对象(按初始化列表的顺序),然后是实际类的构造函数。我在这里怎么了?
#include <iostream>
class A
{
public:
A(int n = 0)
: m_i(n)
{
std::cout << m_i;
++m_i;
}
protected:
int m_i;
};
class B
: public A
{
public:
B(int n = 5) : m_a(new A[2]), m_x(++m_i) { std::cout << m_i; }
~B() { delete[] m_a; }
private:
A m_x;
A* m_a;
};
int main()
{
B b;
std::cout << std::endl;
return 0;
}
答案 0 :(得分:2)
成员变量的初始化顺序始终是声明顺序,而不是构造函数初始化列表顺序。
这意味着B::m_x
将首先被初始化,因为它是在类中首先声明的。
例如参见this initialization order reference了解详情。