Шаблонная функция typedefs не будет компилироваться - PullRequest
4 голосов
/ 30 ноября 2010
#include <iostream>
#include <string>
using namespace std;

void printstr( const string & s ) { cout << s << endl; }

template < typename A >
class Test
{
public:
    typedef void (*Func)( const A & );
};

typedef void (*Func)( const string & );

template < typename A >
void bind(
        Test< A >::Func f,           //<---- does NOT compile
        //Func f,                    //<---- compiles & works!
        //void (*f)( const A & ),    //<---- compiles & works!
        const A & a) { f( a ); }


int main( )
{
    bind( printstr, string("test") );
    return 0;
}

В приведенном выше коде я пытаюсь использовать указатель на функцию typedef из другого класса.Как показано, он не компилируется, но с любой из двух других строк, не закомментированных вместо строки Test< A >::Func f,, он компилируется нормально!Это то, что я не могу сделать в C ++?Какой синтаксис нужен?

Используя g ++ 4.4.3, я получаю

test.cpp:20: error: variable or field "bind" declared void
test.cpp:20: error: expected ")" before "f"
test.cpp:23: error: expected primary-expression before "const"

1 Ответ

7 голосов
/ 30 ноября 2010

Имя Test<A>::Func является зависимым именем и должно начинаться с префикса typename

typename Test< A >::Func f,  

Для более подробного объяснения вы должны проверить объяснение Йоханнеса в следующем ответе

...