类成员的声明顺序决定初始化顺序;
构造函数初始化列表不影响初始化顺序;
C++初始化类成员时,是按照声明的顺序初始化的,而不是按照出现在初始化列表中的顺序。
class B
{
public:
//m_b = 2,m_a = 1
B():m_a(1),m_b(m_a+1)
{
cout << "m_b = " << m_b << ",m_a = " << m_a << endl;
}
//m_b = 2,m_a = 1
B():m_b(m_a+1),m_a(1)
{
cout << "m_b = " << m_b << ",m_a = " << m_a << endl;
}
//上述两个结果一样的,可以判断初始化顺序由声明顺序决定。
//m_b = 1,m_a = -1218015231
B():m_b(1),m_a(m_b+1)
{
cout << "m_b = " << m_b << ",m_a = " << m_a << endl;
}
private:
//声明顺序
int m_a;
int m_b;
};
int main()
{
B b;
}
例子:
#include <iostream>
using namespace std;
class A
{
public:
A():a(1),b(8){cout<< "A()"<<endl;}
int a;
int b;
};
class B
{
public:
B():m_b(a.b),m_a(a.a) //构造函数初始化列表
{
cout << "m_b = " << m_b << ",m_a = " << m_a << endl;
}
private:
//下列为:声明顺序
int m_a;
//A a;
int m_b;
A a;
};
class C: public B
{};
int main()
{
B b;
C c;
return 1;
}
不同情况,两种结果:
当使用//A a;时,下面结果:m_a为随机值
A()
m_b = 8,m_a = 0
A()
m_b = 8,m_a = -1076785724
当使用A a;时,下面结果:m_a、m_b为随机值
A()
m_b = -1218158592,m_a = 134514971
A()
m_b = -1219712267,m_a = -1076671652
本文探讨了C++中构造函数初始化列表的工作原理及其对成员变量初始化的影响。通过实例说明成员变量的初始化顺序取决于它们在类中的声明顺序,而非初始化列表中的顺序。
&spm=1001.2101.3001.5002&articleId=52980355&d=1&t=3&u=94c983fb29ab498e8586047c5f4e9426)
597

被折叠的 条评论
为什么被折叠?



