Mesurer le temps d'exécution d'une fonction en C
Pour évaluer le temps d'exécution d'une fonction spécifique dans votre programme C, plusieurs mesures de temps des techniques sont disponibles. Cependant, pour une mesure précise sur un système Linux, la fonction process_user_cpu_clock de Boost.Chrono est recommandée.
Cette fonction identifie le temps que le processeur passe à exécuter la fonction spécifiée, à l'exclusion de tout temps passé sur d'autres processus ou tâches système. Voici un extrait de code illustrant son utilisation :
#include <boost/chrono/process_time_clock.hpp> using namespace boost::chrono; boost::chrono::process_time_clock::time_point start, end; // Function whose execution time is being measured void my_function() { /* ... */ } start = process_user_cpu_clock::now(); my_function(); end = process_user_cpu_clock::now(); duration<double> total_time = end - start; cout << "Execution time: " << total_time.count() << " seconds" << endl;
Dans le code ci-dessus, les variables de début et de fin capturent le temps CPU au début et à la fin de l'appel my_function, respectivement. La variable total_time stocke ensuite la différence de temps, qui représente le temps d'exécution de la fonction.
Notez que la méthode ci-dessus mesure le temps CPU en mode utilisateur et n'inclut pas le temps passé dans le système d'exploitation ou d'autres processus. De plus, il est important de considérer la possibilité de changements de contexte et d'opérations d'E/S, qui peuvent affecter la précision de la mesure.
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!