Décider d'appeler une fonction statique ou non statique en fonction de la syntaxe d'appel peut être une fonctionnalité souhaitable. Cependant, en C , obtenir cet effet peut être difficile.
La norme C interdit explicitement la surcharge de fonctions qui diffèrent uniquement en termes de déclaration statique ou non statique. Plus précisément, toutes les fonctions membres avec des signatures identiques, y compris les variantes statiques et non statiques, ne peuvent pas être surchargées.
<code class="cpp">class Foo { static void print(); void print(); // Compiler error: cannot overload with static function };</code>
De plus, il est possible d'appeler des fonctions statiques en utilisant la syntaxe membre de classe, ce qui introduirait une ambiguïté. s'il existe plusieurs fonctions avec la même signature.
<code class="cpp">class Foo { static void print(); void print(); }; int main() { Foo f; f.print(); // Ambiguous: which print function is being called? }</code>
Pour déterminer la fonction spécifique à appeler, on peut envisager d'utiliser le mot-clé this. Cependant, cela pointe toujours vers l'objet pour lequel la fonction est invoquée, ce qui la rend impropre à la différenciation entre les appels statiques et non statiques.
<code class="cpp">// This keyword is always non-NULL, making it impossible to determine static vs. non-static calls. cout << (this == nullptr ? "static" : "non-static");</code>
En conclusion, alors que PHP fournit un moyen de distinguer entre les appels statiques et non statiques. appels de fonction non statiques, C n’a pas de mécanisme équivalent. Les fonctions statiques et non statiques doivent avoir des signatures uniques ou utiliser des mécanismes supplémentaires pour obtenir le comportement souhaité.
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!