не шаблонный с одним и тем же именем; и если мы переопределим его нешаблонного собрата в наследованом классе, то нельзя вызвать шаблонный метод из объекта наследника? Описание сумбурное, приложу код
struct Base
{
template<typename T>
void callMe() {
cout << "template called" << endl;
}
virtual void callMe() {
cout << "non-template called" << endl;
}
};
struct Derived : public Base
{
void callMe() override {
cout << "non-template override called" << endl;
}
};
struct Derived2 : public Base
{
};
int main() {
Base b;
b.callMe(); // works
b.callMe<bool>(); // works
Derived d;
d.callMe(); // works
// d.callMe<bool>(); // doesn't work
static_cast<Base*>(&d)->callMe<bool>(); // works
Derived2 d2;
d2.callMe(); // works
d2.callMe<bool>(); // works
return 0;
}
Поиск имени callMe заканчивается при обнаружении его в Derived, чисто в этом проблема. Надо полным именем дёргать (в стиле d2.Base::callMe), либо using написать в Derived
Обсуждают сегодня