So I have a couple classes defined thusly:
class StatLogger {
public:
StatLogger();
~StatLogger();
bool open(<parameters>);
private:
<minutiae>
};
And a child class that descends from it to implement a null object pattern (unopened it’s its own null object)
class NullStatLogger : public StatLogger {
public:
NullStatLogger() : StatLogger() {}
};
Then I have a third class that I want to take an optional logger instance in its constructor:
class ThirdClass {
public:
ThirdClass(StatLogger& logger=NullStatLogger());
};
My problem is when I do it as above, I get:
error: default argument for parameter
of type ‘StatLogger&’ has type
‘NullStatLogger’
And if I put an explicit cast in the definition, I get:
error: no matching function for call
to
‘StatLogger::StatLogger(NullStatLogger)
Complaining about not having a constructor from a NullStatLogger even though it’s a child class. What am I doing wrong here, is this allowed in C++?
I you want to use inheritance and polymorphism,
ThirdClassneeds to use either a pointer or a reference toStatLoggerobject, not with an actual object. Likewise, under the circumstances you almost certainly need to makeStatLogger::~StatLogger()virtual.For example, modified as follows, the code should compile cleanly:
Edit: If you prefer a reference, the code looks something like this: