views:

246

answers:

1

Is it OK to have a static member variable defined in a base class, and having several derived classes each using its own instance of this member variable?

The following code compiles successfully, and prints the right output, but I am still not sure that doing something like that is a good practice. In the following example, how can it work, if I explicitly define only one instance of s (by calling: string A::s;) but I actually use 2 instances?

class A 
{
   protected:
    void SetS(string new_s){s = new_s;}
    void PrintS(){cout << s << endl;};
   private:
    static string s;

};

class B : public A
{
   public:
    void foo(){ SetS("bbb"); PrintS();};
};

class C : public A
{
   public:
    void foo(){ SetS("ccc"); PrintS();};
};

string A::s;

int main()
{
    B b;
    b.foo(); // results in output: bbb
    C c;
    c.foo(); // results in output: ccc
    b.foo(); // results in output: bbb
}
+7  A: 

A very odd use of inheritance indeed. The base class is supposed to define interfaces ideally and contain as little or no state at all if possible according to good OO design principle.

This works because your foo() resets the value of A::s everytime it is called. Try printing the address of A::s. There is one and only one object. This will not work if you don't set the value everytime and you have multiple objects using another member function bar() to read the value of A::s.

You may run into sync issues if B and C objects are created in separate threads as well. You will end up with UB.

dirkgently
Excellent answer. +1.
Hosam Aly
Thank you, it completely answered my question.
Igor Oks
The base class is supposed to define interfaces. But base class can be just working extension.
Mykola Golubyev
@Mykola Golubyev: I am not too sure what you mean. Anyway, the opening paragraph was more of a comment on the general state of things and not the problem in hand which I address later on.
dirkgently