Résolution de surcharge en C
En C, la résolution de surcharge est le processus par lequel le compilateur détermine quelle surcharge de fonction appeler en fonction des arguments donnés . Bien que ce processus fonctionne généralement automatiquement, il existe des cas où des remplacements explicites sont nécessaires.
Considérons l'exemple suivant :
<code class="cpp">class A { public: int DoSomething() { return 0; } }; class B : public A { public: int DoSomething(int x) { return 1; } }; int main() { B* b = new B(); b->DoSomething(); // Error: No matching overload found }</code>
Ici, la classe B hérite de la méthode DoSomething() de A et remplace avec une nouvelle surcharge qui accepte un argument entier. Si vous essayez d'appeler DoSomething() sans spécifier la méthode remplacée (b->DoSomething();), le compilateur générera une erreur car il ne peut pas déterminer quelle surcharge appeler.
Pour résoudre cette ambiguïté, vous devez spécifier explicitement la méthode DoSomething() de la classe de base à l'aide de l'opérateur de résolution de portée :
<code class="cpp">b->A::DoSomething();</code>
Cette syntaxe indique clairement que vous souhaitez appeler la méthode DoSomething() définie dans la classe A. Le comportement par défaut de la Le compilateur consiste à rechercher la fonction surchargée dans la portée la plus petite possible, qui dans ce cas est la portée de la classe B.
Une solution alternative consiste à utiliser la directive using pour amener la méthode DoSomething() de la classe de base dans la portée de B :
<code class="cpp">class B : public A { public: using A::DoSomething; };</code>
Avec cette directive, vous pouvez désormais appeler DoSomething() sur des objets de type B sans spécifier la portée de la classe de base.
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!