Ambiguïté littérale de chaîne dans la surcharge de fonctions avec bool
Lors de la définition de méthodes surchargées qui acceptent à la fois les arguments bool et std::string, les développeurs peuvent rencontrer comportement inattendu lors de la fourniture de chaînes littérales. Au lieu d'invoquer la surcharge std::string, la surcharge bool est prioritaire.
Pour comprendre ce comportement, considérez la situation suivante :
<code class="cpp">class Output { public: static void Print(bool value) { std::cout << value ? "True" : "False"; } static void Print(std::string value) { std::cout << value; } }; Output::Print("Hello World");</code>
Malgré la fourniture d'un littéral de chaîne, le Print( ) avec la surcharge booléenne est invoquée. En effet, les chaînes littérales en C peuvent être implicitement converties en valeurs booléennes. Plus précisément, "Hello World" est un tableau const char* qui peut être interprété comme un pointeur vers un const char, qui à son tour peut être implicitement converti en booléen. Cette conversion est considérée comme une séquence de conversion standard.
C donne la priorité aux séquences de conversion standard par rapport aux conversions définies par l'utilisateur (par exemple, la conversion de std::string en bool). Selon la norme C (§13.3.3.2/2), une séquence de conversion standard est toujours considérée comme une meilleure séquence de conversion.
Ce comportement peut être modifié en fournissant explicitement un argument std::string au Print( ) méthode :
<code class="cpp">Output::Print(std::string("Hello World"));</code>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!