我的课如下:

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/

10-11 21:31