#include <iostream>
class A {
public:
A(){
std::cout << " construct A(): c "<< c << '\n';
};
A(int x):c(x){
std::cout <<" construct A(int x): x and c "<<x<<" "<<c<< "\n";
};
~A(){};
protected:
int c;
void f();
};
void A::f(){
std::cout <<" A::f() "<< c << "\n";
}
class B: public A{
public:
B(){
std::cout << " construct B(): c "<< c << '\n';
};
B(int x){
std::cout <<" construct B(int x): x "<<x<<"\n";
};
~B(){};
void g();
};
void B::g()
{
int d=c; // allowed
std::cout <<" B::g() c and d: "<< c<<" "<<d << "\n";
f(); // allowed
}
int main () {
A a(4);
B b(4);
// a.f () ; // forbidden
b.g() ; // forbidden
}
construct A(int x): x and c 4 4
construct A(): c 0
construct B(int x): x 4
B::g() c and d: 0 0
A::f() 0
A类带参构造函数被调用之后,使用带参的构造函数初始化了一个B类,其中B类构造函数初始化前自动调用了A的无参构造函数。因此重置了保护变量c?
如果要避免初始化派生类时重新初始化父类该怎么办?
你说的和代码根本不是一回事,似乎你对这个类、实例、构造之间的概念和关系还不清楚。
类只是模型,实例虽然是按模型生成的,但每个模型是完全独立的个体,相互之间是没有关系的。
你这里A定义了变量a,初始化值为4。A类的带参构造函数使得a变量的c成员变量初始化为4
然后你定义B类变量b,带参数为4,但实际B的构造函数根本没有使用这个参数,导致子类B构造时,基类A的变量c没有初始化。所以默认为0,输出了c 0这样的信息
变量a和变量b虽然在生成的时候使用了父子类,但它们一旦成为实例就没有关系了,各自有独立的存储空间。