Maison >développement back-end >C++ >Pourquoi `std :: cout

Pourquoi `std :: cout

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-10-28 02:37:311115parcourir

Why does `std::cout

Curieux cas de f; Pourquoi imprime-t-il toujours 1 dans la sortie ?

Rencontrer un comportement particulier où appeler une fonction sans parenthèses (f;) et imprimer son résultat avec std::cout donne systématiquement le numéro 1 peut soulever des questions. Au départ, on pourrait s'attendre à ce que le code imprime un pointeur de fonction, mais les observations indiquent le contraire.

En examinant le code ci-dessous :

<code class="cpp">#include <iostream>
using namespace std;

void pr()
{
    cout << "sth";
}

int main()
{
    pr;
    cout << pr;  // output: 1
    cout << *pr; // output: 1
    cout << &pr; // output: 1
}

Nous pouvons voir que pr; techniquement, n'appelle pas la fonction pr(). Au lieu de cela, le pointeur de fonction est transmis à cout. Lorsque le pointeur de fonction est converti en booléen au cours de ce processus, il se comporte comme une expression logique dans laquelle une valeur non nulle est évaluée comme vraie. Cela se traduit par 1 une fois imprimé.

De plus, dans la norme pré-C 11, il n'existe aucune surcharge permettant de diffuser un pointeur de fonction. Cela rend difficile le formatage et l'impression des pointeurs de fonction directement à l'aide de std :: cout. Cependant, avec l'avènement de C 11, on peut définir une surcharge personnalisée pour y parvenir :

<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) << ")";
}

En employant cette surcharge, cout << pr va maintenant imprimer :

<code class="text">(func_ptr=<address of pr>)(num_args=0)</code>

Cette surcharge personnalisée démontre l'impression de pointeurs de fonction d'arité variable. Bien que cela atténue le problème des pointeurs de fonction, cela ne résout pas complètement les scénarios impliquant des fonctions ou des modèles de fonctions surchargés où la spécification de la surcharge souhaitée devient essentielle.

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