Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Problem accessing base member in derived constructor

Given the following classes:

class Foo
{
    struct BarBC
    {
    protected:
        BarBC(uint32_t aKey)
            : mKey(aKey)
              mOtherKey(0)

    public:
        const uint32_t mKey;
        const uint32_t mOtherKey;
    };


    struct Bar : public BarBC
    {
        Bar(uint32_t aKey, uint32_t aOtherKey)
            : BarBC(aKey),
              mOtherKey(aOtherKey) // Compile error here
    };
};

I am getting a compilation error at the point indicated:

error: class `Foo::Bar' does not have any field named `mOtherKey'.

Can anyone explain this? I suspect it's a syntactical problem due to my Bar class being defined within the Foo class, but can't seem to find a way around it.

This is simple public inheritance, so mOtherKey should be accessible from the Bar constructor. Right?

Or is it something to do with the fact that mOtherKey is const and I have already initialised it to 0 in the BarBC constructor?

like image 714
LeopardSkinPillBoxHat Avatar asked Jan 22 '23 23:01

LeopardSkinPillBoxHat


2 Answers

You can't initialize members of a base class through a member initializer list, only direct and virtual base classes and non-static data members of the class itself.
Pass additional parameters to the base class' constructor instead:

struct BarBC {
    BarBC(uint32_t aKey, uint32_t otherKey = 0)
      : mKey(aKey), mOtherKey(otherKey)
    {}
    // ...
};

struct Bar : public BarBC {
    Bar(uint32_t aKey, uint32_t aOtherKey)
      : BarBC(aKey, aOtherKey)
    {}
};
like image 121
Georg Fritzsche Avatar answered Jan 24 '23 14:01

Georg Fritzsche


You can't do this as BarBC constructs the mOtherKey - you can't override it.

You have either assign new value:

Bar(...) : ...
{ mOtherKey=aOtherKey; }

Or create additional BarBC constructor that has a parameter of mOtherKey

like image 23
Artyom Avatar answered Jan 24 '23 12:01

Artyom