Нет соответствующего вызова функции для

#c #templates #enums

#c #шаблоны #перечисления

Вопрос:

Учитывая:

 template<typename T>
void f( T ) {
}

enum {    // if changed to "enum E" it compiles
  e
};

int main() {
  f( e ); // line 10
}
  

Я получаю:

 foo.cpp: In function ‘int main()’:
foo.cpp:10: error: no matching function for call to ‘f(<anonymous enum>)’
  

Тем не менее, если enum объявлению присвоено имя, оно компилируется. Почему это не работает для анонимного перечисления? В идеале, я бы хотел, чтобы это повышало значение enum e до int и создавало экземпляр f(int) .

Ответ №1:

Безымянный тип просто не может использоваться в качестве аргумента шаблона

C 03 говорит в 14.3.1[temp.arg.type]/2

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

Это ограничение было снято в C 0x, и ваша программа компилируется без диагностики с MSVC 2010 и gcc 4.5.2 в режиме C 0x.

Ответ №2:

В идеале, я бы хотел, чтобы он преобразовал значение перечисления e в значение int и создал экземпляр f (int).

 f( e);
  

Ответ №3:

Вы всегда можете явно выполнить продвижение, чтобы четко показать свое намерение:

f(static_cast<int>(e));