我的课如下:
class base
{
protected:
int x;
int y;
int z;
public:
base(int x, int y, int z)
{
x = x;
y = y;
z = z;
}
virtual void show();
};
我从上面派生一个类为:
class derived : protected base
{
public:
int a;
int b;
int c;
derived(int a, int b, int x, int y, int z) : base(x, y, z) //initialising the base class members as well
{
cout<<a<<b<<x<<y<<z; //works fine
a = a;
b = b;
}
void show()
{
cout<<a<<b<<x<<y<<z; //show junk values
}
//some data members and member functions
};
在main()中,我使用:
derived d(1, 2, 3, 4, 5);
d.show();
数据成员在构造函数内部似乎具有合法值。但是,当我使用类似的功能(即具有相同的可见性模式)时,似乎会出现垃圾值。
最佳答案
a = a;
b = b;
应该
this->a = a;
this->b = b;
或者,甚至更好的是,使用初始化列表:
derived(int a, int b, int x, int y, int z) : a(a), b(b), base(x,y,z)
{
cout<<a<<b<<x<<y<<z; //works fine
}
您正在执行的操作是自动分配参数,因此不会设置成员。
关于c++ - 垃圾值-C++中的继承,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/12552229/