web-dev-qa-db-fra.com

Pourquoi le compilateur préfère-t-il f (const void *) à f (const std :: string &)?

Considérez le morceau de code suivant:

#include <iostream>
#include <string>

// void f(const char *) { std::cout << "const char *"; } // <-- comment on purpose
void f(const std::string &) { std::cout << "const std::string &"; }
void f(const void *) { std::cout << "const void *"; }

int main()
{
    f("hello");
    std::cout << std::endl;
}

J'ai compilé ce programme en utilisant g++ (Ubuntu 6.5.0-1ubuntu1~16.04) 6.5.0 20181026:

$ g++ -std=c++11 strings_1.cpp -Wall
$ ./a.out

const void *

Notez que le commentaire est là pour tester, sinon le compilateur utilise f(const char *).

Alors, pourquoi le compilateur choisit-il f(const void*) plutôt que f(const std::string &)?

47
omar

Conversion en std::string nécessite une "conversion définie par l'utilisateur".

Conversion en void const* ne fait pas.

Les conversions définies par l'utilisateur sont ordonnées derrière celles intégrées.

54