Why do pure virtual base classes get direct access to static data members while derived instances do
Posted
by Shamster
on Stack Overflow
See other posts from Stack Overflow
or by Shamster
Published on 2010-04-08T06:06:54Z
Indexed on
2010/04/08
6:13 UTC
Read the original article
Hit count: 326
I've created a simple pair of classes. One is pure virtual with a static data member, and the other is derived from the base, as follows:
#include <iostream>
template <class T>
class Base {
public:
Base (const T _member) {
member = _member;
}
static T member;
virtual void Print () const = 0;
};
template <class T> T Base<T>::member;
template <class T> void Base<T>::Print () const { std::cout << "Base: " << member << std::endl; }
template <class T>
class Derived : public Base<T> {
public:
Derived (const T _member) : Base<T>(_member) { }
virtual void Print () const { std::cout << "Derived: " << this->member << std::endl; }
};
I've found from this relationship that when I need access to the static data member in the base class, I can call it with direct access as if it were a regular, non-static class member. i.e. - the Base::Print() method does not require a this-> modifier.
However, the derived class does require the this->member indirect access syntax. I don't understand why this is. Both class methods are accessing the same static data, so why does the derived class need further specification?
A simple call to test it is:
int main () {
Derived<double> dd (7.0);
dd.Print();
return 0;
}
which prints the expected "Derived: 7"
© Stack Overflow or respective owner