2013-10-07 4 views
3

Следующий код вызывает ошибку компилятора при компиляции.Как метод принимает const char * как аргумент, близкий к методу, принимающему const int &?

template <typename T> 
inline T const& max (T const& a, T const& b) 
{ 
    return a < b ? b : a; 
} 

// maximum of two C-strings (call-by-value) 
inline char const* max (char const* a, char const* b) 
{ 
    return strcmp(a,b) < 0 ? b : a; 
} 

// maximum of three values of any type (call-by-reference) 
template <typename T> 
inline T const& max (T const& a, T const& b, T const& c) 
{ 
    return max (max(a,b), c); 
} 

int main() 
{ 
    ::max(7, 42, 68); 
} 

На компиляции я получаю ошибку:

error: call of overloaded 'max(const int&, const int&)' is ambiguous

note: candidates are:

note: const T& max(const T&, const T&) [with T =int]

note: const char* max(const char*, const char*)

Как макс (Const символ *, Const символ *) становится почти спичку для макс (константный Int &, Const INT &), когда мы есть метод шаблона, который соответствует вызову?

+0

попробовать это 'константный символ * x = 42; 'и что должно anser ур вопрос – Kal

+2

Какой компилятор? Он отлично работает для меня: http://coliru.stacked-crooked.com/a/d125ccc03238992e – aschepler

+0

Ваша функция возвращает const-reference, и вы передаете tempval. технически шаблон не подходит. Изменяется ли это, если вы удаляете 'const &' из возвращаемого типа шаблона? – WhozCraig

ответ

1

Уверен, у вас есть using namespace std в вашем коде. Удалите его, и все будет хорошо.

Сравнить: http://ideone.com/Csq8SV и http://ideone.com/IQAoI6

Если строго необходимо патезрасе для использования, вы можете заставить корень пространства имен вызов (так, как это сделать в main()):

template <typename T> 
inline T const& max (T const& a, T const& b, T const& c) 
{ 
    return ::max(::max(a,b), c); 
}