2

我有一堂课如下:

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();

数据成员似乎在构造函数中具有合法值。但是,当我使用类似的功能,即使用相同的可见性模式时,似乎会出现垃圾值。

4

2 回答 2

5
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
}

您正在做的是自行分配参数,因此不会设置成员。

于 2012-09-23T12:09:20.897 回答
3

你永远不会初始化你的成员变量。a=a;将分配给局部变量a(参数),而不是成员变量。应该是this->a=a;。其他成员也一样。

于 2012-09-23T12:10:29.540 回答