C ++ вызывает шаблонные функции базового класса - PullRequest
7 голосов
/ 08 февраля 2011

Ниже приведены два случая.

Случай 1) Base-> BaseIndirect-> DerivedIndirect

Case 2) Base-> Derived

В случае 2), я могу вызвать функцию шаблона для Baseкласс с использованием 3 обозначений.В случае 1) я могу вызвать функцию шаблона базового класса, используя только одну из этих нотаций.И я НЕ могу вызвать функцию шаблона BaseIndirect, используя любые обозначения :(. Как это исправить? Спасибо.

struct Base {
  template<bool R> inline void fbase(int k) {};
};

template<class ZZ> struct BaseIndirect : Base {
  template<bool R> inline void fbaseIndirect(int k) {};
};


template<class ZZ>
struct DerivedIndirect : BaseIndirect<ZZ> {
  DerivedIndirect() {
    this->fbase<true>(5);         // gives error, line 13
    fbase<true>(5);               // gives error, line 14
    Base::fbase<true>(5);           // WORKS, line 15
    this->fbaseIndirect<true>(5); // gives error, line 16
    fbaseIndirect<true>(5);       // gives error, line 17
    BaseIndirect<ZZ>::fbaseIndirect<true>(5);   // gives error, line 18
  }
};

template<class ZZ>
struct Derived : Base {
  Derived() {
    this->fbase<true>(5); //  WORKS
    fbase<true>(5);       // WORKS
    Base::fbase<true>(5); // WORKS
  }
};


int main() {
  Derived<int> der;
  DerivedIndirect<int> derIndirect;
};                              

ОШИБКИ при компиляции

test.cpp: In constructor 'DerivedIndirect<ZZ>::DerivedIndirect()':
test.cpp:14: error: 'fbase' was not declared in this scope
test.cpp:17: error: 'fbaseIndirect' was not declared in this scope
test.cpp: In constructor 'DerivedIndirect<ZZ>::DerivedIndirect() [with ZZ = int]':
test.cpp:34:   instantiated from herep 
test.cpp:13: error: invalid operands of types '<unresolved overloaded function type>' and 'bool' to binary 'operator<'
test.cpp:16: error: invalid operands of types '<unresolved overloaded function type>' and 'bool' to binary 'operator<'
test.cpp:18: error: invalid operands of types '<unresolved overloaded function type>' and 'bool' to binary 'operator<'

1 Ответ

14 голосов
/ 08 февраля 2011

Причина, по которой многие из этих вызовов терпят неудачу, заключается в том, что существует синтаксическая неоднозначность, которую необходимо устранить, используя одно из самых неясных случаев использования ключевого слова template.Вместо записи

this->fbase<true>(5);

Вам необходимо написать

this->template fbase<true>(5);

Причина в том, что без ключевого слова template компилятор анализирует это как

(((this->fbase) < true) > 5)

Что бессмысленно.Ключевое слово шаблона явно устраняет эту неоднозначность.Добавление ключевого слова template в другие упомянутые вами случаи должно исправить эти проблемы.

На самом деле я не уверен, почему это работает для прямых базовых классов, поэтому если бы кто-то мог ответить на эту часть вопроса, я былюблю видеть, что ответ.

...