Как должен вести себя этот код? Он вызывает общую функцию, игнорируя мою перегрузку, если я использую квалифицированное имя в функции call_read ()
; и он сначала вызывает перегрузку, а затем общую версию, если я использую неквалифицированное имя. Какая разница? Это ошибка в GCC?
#include
struct info1 {};
struct info2 {};
template void read(T& x)
{
std::cout << "generic" << std::endl;
}
template void call_read(T& x)
{
::read(x); // if I replace ::read(x) with read(x) the overload is called
}
void read(info1& x)
{
std::cout << "overload" << std::endl;
}
int main()
{
info1 x;
info2 y;
call_read(x);
call_read(y);
}
Я также заметил, что он работает по-другому для основных типов. См. Код ниже
#include
typedef struct info1 {};
typedef struct info2 {};
typedef int info3;
typedef double info4;
template void read(T x)
{
std::cout << "generic" << std::endl;
}
template void call_read(T x)
{
read(x);
}
void read(info1 x)
{
std::cout << "overload" << std::endl;
}
void read(info3 x)
{
std::cout << "overload" << std::endl;
}
int main()
{
call_read(info1());
call_read(info2());
call_read(info3());
call_read(info4());
}
Предполагается, что перегруженная функция вызывается дважды, но это не так. Смотрите результат здесь http://codepad.org/iFOOFD52