


Comment puis-je mesurer avec précision le temps d'exécution en Go ?
Dec 05, 2024 pm 01:15 PMMesurer 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)
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!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

GO Language Pack Import: Quelle est la différence entre le soulignement et sans soulignement?

Comment mettre en œuvre le transfert d'informations à court terme entre les pages du cadre Beego?

Comment écrire des objets et des talons simulés pour les tests en Go?

Comment puis-je utiliser des outils de traçage pour comprendre le flux d'exécution de mes applications GO?

Comment convertir la liste des résultats de la requête MySQL en une tranche de structure personnalisée dans le langage Go?

Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go?

Comment écrire des fichiers dans GO Language de manière pratique?

Comment puis-je utiliser des liners et des outils d'analyse statique pour améliorer la qualité et la maintenabilité de mon code GO?
