Ho la seguente definizione.Sovraccarico funzione template 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;
}
Poi emette
1
Dalla mia comprensione, entrambe le versioni devono passare attraverso una conversione const. Quindi void foo(const T *s)
è più specializzato e dovrebbe essere invocato. Tuttavia il compilatore ha scelto void foo(const T& s)
. Qual è la spiegazione?
'const T & s' ->' T const e s' -> 'T = char *' -> 'char * const &' –
sto compilando e ancora non riesco a credere che sceglie 1 – bolov