Могу ли я вызвать виртуальную функцию для инициализации подобъекта базового класса?
Я знаю, что виртуальные функции не должны вызываться ни прямо, ни косвенно в конструкторе, но этот код работает нормально.
Что у меня здесь безопасно?
#include <iostream>
#include <string>
struct A {
A (const std::string& name) {std::cout << name << std::endl;}
virtual std::string tag() const = 0;
};
struct B: A {
B() : A (tag()) {}
virtual std::string tag() const override {return "B";}
};
int main() {
B b; // Output gives "B\n"
}
Если нет, то будет ли следующее (на основе комментариев) правильным обходным путем?
// Replacement for class B:
struct B: A {
B() : A (name()) {}
virtual std::string tag() const override {return name();}
private:
static std::string name() {return "B";} // use static function
};