Maison > développement back-end > Golang > Comment puis-je mesurer avec précision le temps d'exécution en Go ?

Comment puis-je mesurer avec précision le temps d'exécution en Go ?

Patricia Arquette
Libérer: 2024-12-05 13:15:12
original
231 Les gens l'ont consulté

How Can I Precisely Measure Execution Time in Go?

Mesurer avec précision la durée du temps dans Go

Bien que la plupart des applications utilisent le package de temps standard pour mesurer la durée, il est crucial de remédier à ses limites pour obtenir des résultats précis. time.Now() s'appuie sur l'heure du système, qui peut être affectée par les changements de fuseau horaire et la synchronisation de l'horloge avec les serveurs NTP.

Pour surmonter ces défis, Go fournit une « horloge monotone » qui n'est pas affectée par l'heure externe. ajustements. À partir de Go 1.9, les durées dans Go exploitent automatiquement cette horloge monotone.

Cela signifie que le code suivant calcule toujours un temps écoulé positif d'environ 20 millisecondes, même si l'horloge murale change pendant l'opération chronométrée :

start := time.Now()
... operation that takes 20 milliseconds ...
t := time.Now()
elapsed := t.Sub(start)
Copier après la connexion

D'autres idiomes comme time.Since(start), time.Until(deadline) et time.Now().Before(deadline) sont également résistants aux réinitialisations de l'horloge murale.

Par conséquent, pour mesurer avec précision le temps d'exécution dans Go, utilisez simplement time.Now() et time.Sub() du package time. fonctions. Ces fonctions garantissent désormais que les mesures du temps écoulé sont cohérentes et ne sont pas affectées par les ajustements de l'horloge 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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal