Maison >développement back-end >C++ >Comment puis-je mesurer avec précision le temps d'exécution d'un extrait de code C ?

Comment puis-je mesurer avec précision le temps d'exécution d'un extrait de code C ?

Linda Hamilton
Linda Hamiltonoriginal
2024-11-28 15:00:16271parcourir

How Can I Accurately Measure the Execution Time of a C   Code Snippet?

Comment calculer avec précision le temps d'exécution d'un extrait de code en C

Mesurer le temps d'exécution d'un extrait de code est crucial pour optimiser les performances du code. Cet article explique comment calculer efficacement le temps d'exécution d'un extrait de code C, garantissant ainsi la précision même pour des instructions courtes ou de petites entrées.

Limitations de l'horloge :

L'horloge (), bien qu’elle soit largement utilisée, présente des limites lors de la mesure de courtes durées. Il renvoie le temps CPU consommé par le processus, qui peut être grossier et donner des résultats « 0 seconde » pour des tâches brèves.

Solution : Utilisation de la fonction GetTimeMs64() :

Pour pallier ces limitations, la fonction GetTimeMs64() fournit une mesure plus précise du temps écoulé. Il utilise l'horloge système sous Windows et Linux, fournissant des résultats précis même pour des durées d'une minute.

Détails de mise en œuvre :

La fonction GetTimeMs64() obtient le nombre de millisecondes depuis l'époque UNIX. Cela fonctionne par :

  • Windows :

    • Récupère l'heure du système sous forme de FILETIME et la convertit en une structure LARGE_INTEGER.
    • Ajuste le résultat pour qu'il corresponde à l'heure UNIX dans millisecondes.
  • Linux :

    • Acquiert l'heure actuelle à l'aide de gettimeofday().
    • Convertit la valeur des microsecondes en millisecondes.
    • Ajoute la valeur des secondes, également convertie en millisecondes.

Utilisation :

Pour mesurer le temps d'exécution d'un extrait de code à l'aide de la fonction GetTimeMs64() :

  1. Inclure l'en-tête GetTimeMs64.h fichier.
  2. Appelez GetTimeMs64() avant d'exécuter l'extrait de code.
  3. Appelez à nouveau GetTimeMs64() une fois l'extrait de code terminé.
  4. Calculez le temps écoulé en soustrayant le temps initial temps depuis la finale time.

Avantages de GetTimeMs64() Fonction :

  • Précision : Fournit des résultats plus précis, en particulier pour les courtes durées .
  • Multiplateforme : Fonctionne efficacement sur les deux Windows et systèmes Linux.
  • Sécurité des threads : Utilisation sûre dans des environnements multithread.

Considérations :

  • La granularité temporelle de GetTimeMs64() est généralement de 15 ms sous Windows et peut varier selon Linux.
  • Cette fonction mesure le temps d'horloge écoulé, qui peut inclure des retards liés au système.

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