Mesurer la vitesse du code PHP : deux solutions efficaces
Lorsque l'on compare l'efficacité des classes de code effectuant des tâches identiques, il est crucial d'évaluer leur rapidité d'exécution. Cet article présente deux solutions pour relever ce défi :
Solution naïve : analyse comparative microtime
Cette méthode utilise la fonction microtime(true) de PHP pour déterminer la durée d'exécution du code. Il s'agit de placer la fonction avant et après la section de code pour calculer le temps écoulé. Par exemple, pour mesurer le temps nécessaire à la sérialisation d'un tableau :
$before = microtime(true); for ($i = 0; $i < 100000; $i++) { serialize($list); } $after = microtime(true); echo ($after - $before) / $i . " sec/serialize\n";
Cette solution convient pour comparer des extraits de code court impliquant des fonctions simples.
Solution avancée : profilage Xdebug
Pour profiler un script entier afin d'identifier les goulots d'étranglement, l'extension Xdebug offre des informations inestimables. Une fois installé, Xdebug génère des données de profilage qui peuvent être analysées à l'aide d'un logiciel compatible. Trois options populaires incluent :
Pour configurer Xdebug pour le profilage, modifiez les paramètres suivants dans php.ini :
xdebug.profiler_enable = 0 ; Profiling disabled by default xdebug.profiler_enable_trigger = 1 ; Enable profiling with GET parameter xdebug.profiler_output_dir = /tmp/ouput_directory xdebug.profiler_output_name = files_names
En passant le paramètre "XDEBUG_PROFILE" dans l'URL, vous pouvez déclencher de manière sélective le profilage de pages spécifiques. Les données de profilage générées par Xdebug peuvent être visualisées dans des outils comme KCacheGrind, fournissant une représentation graphique de la consommation du temps CPU, vous permettant d'identifier les goulots d'étranglement des performances.
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!