Maison >développement back-end >C++ >Pourquoi l'impression d'un pointeur de fonction sans invocation donne-t-elle \'1\' en C ?

Pourquoi l'impression d'un pointeur de fonction sans invocation donne-t-elle \'1\' en C ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-10-25 07:37:29247parcourir

Why Does Printing a Function Pointer Without Invocation Yield

Impression d'un pointeur de fonction sans invocation : comprendre la sortie mystérieuse de 1

Dans un extrait de code intrigant, une fonction est "appelée" sans en invoquant ses parenthèses ("pr;") puis imprimé en utilisant std::cout. Étonnamment, le résultat donne systématiquement 1, défiant les attentes.

L'énigme des constantes 1

Le code appelle la fonction de trois manières différentes :

<code class="cpp">cout << pr;  // output: 1
cout << *pr; // output: 1
cout << &pr; // output: 1

L'intuition suggère qu'un pointeur de fonction devrait être imprimé au lieu des énigmatiques 1. Cependant, comprendre ce comportement nécessite d'approfondir les mécanismes de conversion de type de C.

Conversion de type et valeurs booléennes

Lorsqu'il est passé comme argument à cout, pr est implicitement converti en booléen. Cette conversion se produit car bool est un type fondamental et cout nécessite un type fondamental en entrée. En C , une valeur booléenne convertie est vraie si la valeur d'origine est différente de zéro et fausse si elle est nulle.

Puisque pr est un pointeur de fonction, sa valeur est une adresse mémoire non nulle. Par conséquent, une fois converti en bool, il est évalué à true, ce qui est affiché comme 1 par cout.

Personnalisation de l'impression du pointeur de fonction (à partir de C 11)

C 11 introduit une surcharge personnalisable qui permet une impression plus informative des pointeurs de fonction :

<code class="cpp">template <class RType, class ... ArgTypes>
std::ostream & operator<<(std::ostream & s, RType(*func)(ArgTypes...))
{
    return s << "(func_ptr=" << (void*)func << ")(num_args=" << sizeof...(ArgTypes) << ")";
}</code>

Cette surcharge imprime l'adresse du pointeur de fonction et le nombre d'arguments qu'il prend. Il peut être utilisé pour imprimer pr comme suit :

<code class="cpp">cout << pr; // output: (func_ptr=0x12345678)(num_args=0)</code>

Cette approche fournit une sortie plus descriptive, facilitant la compréhension des propriétés du pointeur de fonction.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn