Ich habe die folgende Definition.Template Funktion Überladung in C++
using namespace std;
template <typename T>
void foo(const T &s) {
cout << 1;
}
template <typename T>
void foo(const T *s) {
cout << 2;
}
int main(int argc, const char * argv[]) {
char str[] = "ss";
char *s = str;
foo(s);
return 0;
}
Dann gibt es
1
Von meinem Verständnis haben beide Versionen durch eine konstante Umwandlung zu gehen. Dann ist void foo(const T *s)
spezialisierter und sollte aufgerufen werden. Der Compiler hat jedoch void foo(const T& s)
gewählt. Was ist die Erklärung?
'const T & s' ->' T const & s' -> 'T = char *' -> 'char * const &' –
ich es kompilieren und kann immer noch nicht glauben, dass es wählt 1 – bolov