Heim Backend-Entwicklung Golang So erhalten Sie die Funktionsausführungszeit in der Go-Sprache

So erhalten Sie die Funktionsausführungszeit in der Go-Sprache

Jan 17, 2023 am 10:23 AM
golang go语言

In der Go-Sprache können Sie die Funktion Since() im Zeitpaket verwenden, um die Ausführungszeit der Funktion zu erhalten. Legen Sie eine Startzeit fest, bevor die Funktion ausgeführt wird, und ermitteln Sie das Zeitintervall vom Startzeitpunkt bis zum aktuellen Ende der Funktionsausführung. Dieses Zeitintervall ist die Ausführungszeit der Funktion, und die Ausführungszeit der Funktion kann berechnet werden Die Funktion time.Since(). Die Syntax „time.Since(t)“ gibt die von t bis jetzt verstrichene Zeit zurück.

So erhalten Sie die Funktionsausführungszeit in der Go-Sprache

Die Betriebsumgebung dieses Tutorials: Windows 7-System, GO Version 1.18, Dell G3-Computer.

Verwenden Sie die Zeit. Da die Ausführungszeit berechnet wird

Die Länge der Laufzeit der Funktion ist ein wichtiger Indikator zur Messung der Leistung dieser Funktion, insbesondere im Vergleichs- und Benchmark-Test, der einfachste Weg, sie zum Laufen zu bringen Zeit der Funktion: Legen Sie eine Startzeit fest, bevor die Funktion ausgeführt wird, und ermitteln Sie das Zeitintervall von der Startzeit bis zum aktuellen Ende der Funktionsausführung. Dieses Zeitintervall ist die Laufzeit der Funktion.

In der Go-Sprache können wir die Funktion Since() im Zeitpaket verwenden, um die Laufzeit der Funktion zu ermitteln. Die Einführung der Funktion Since() in der offiziellen Dokumentation der Go-Sprache lautet wie folgt. Die Funktion

func Since(t Time) Duration
Nach dem Login kopieren

Since() gibt die von t bis jetzt verstrichene Zeit zurück, was time.Now().Sub(t) entspricht.

Beispiel 1: Verwenden Sie die Funktion Since(), um die Laufzeit der Funktion

package main
import (
    "fmt"
    "time"
)
func test() {
    start := time.Now() // 获取当前时间
    sum := 0
    for i := 0; i < 100000000; i++ {
        sum++
    }
    elapsed := time.Since(start)
    fmt.Println("该函数执行完成耗时:", elapsed)
}
func main() {
    test()
}
Nach dem Login kopieren

zu erhalten. Das laufende Ergebnis lautet wie folgt:

该函数执行完成耗时: 39.8933ms
Nach dem Login kopieren

Wir haben oben erwähnt, dass die Funktion time.Now().Sub() ähnelt der Funktion Since(). Wenn Sie time.Now().Sub() verwenden möchten, um die Laufzeit der Funktion zu erhalten, müssen Sie lediglich Zeile 14 unseres obigen Codes ändern.

Beispiel 2: Verwenden Sie time.Now().Sub(), um die Laufzeit der Funktion

package main
import (
    "fmt"
    "time"
)
func test() {
    start := time.Now() // 获取当前时间
    sum := 0
    for i := 0; i < 100000000; i++ {
        sum++
    }
    elapsed := time.Now().Sub(start)
    fmt.Println("该函数执行完成耗时:", elapsed)
}
func main() {
    test()
}
Nach dem Login kopieren

zu erhalten. Die laufenden Ergebnisse lauten wie folgt:

该函数执行完成耗时: 36.8769ms
Nach dem Login kopieren

Aufgrund des Einflusses der Computer-CPU und einiger anderer Faktoren , wenn die Laufzeit der Funktion abgerufen wird Die Ergebnisse werden jedes Mal leicht unterschiedlich sein, was normal ist.

Wissen erweitern: Verwenden Sie time.Now().Sub(), um den Zeitunterschied zu berechnen

Wir müssen nur time.Since() durch time.Now().Sub() ersetzen, wie folgt:

rrree

Tatsächlich ruft time.Since intern das Zeitpaket auf, um zu sehen, dass „Since“ die seit t vergangene Zeit zurückgibt. Sub(t),

srctimetime.go 923:6

    start := time.Now() // 获取当前时间
    sum := 0
    for i := 0; i < 100000000; i++ {
        sum++
    }
    elapsed := time.Now().Sub(start)
    fmt.Println(elapsed)
Nach dem Login kopieren

Wenn wir auch time.Now().Sub(start).Seconds() verwenden können, um die Anzahl der verstrichenen Sekunden zu erhalten, erhalten wir Stunden Die Anzahl der verstrichenen Stunden usw. kann auch als time.Since(start).Seconds(), time.Since(start).Seconds() usw. abgekürzt werden.

【Verwandte Empfehlungen: Go-Video-Tutorial, Programmierunterricht

Das obige ist der detaillierte Inhalt vonSo erhalten Sie die Funktionsausführungszeit in der Go-Sprache. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Welche Bibliotheken werden für die Operationen der schwimmenden Punktzahl in Go verwendet? Welche Bibliotheken werden für die Operationen der schwimmenden Punktzahl in Go verwendet? Apr 02, 2025 pm 02:06 PM

In der Bibliothek, die für den Betrieb der Schwimmpunktnummer in der GO-Sprache verwendet wird, wird die Genauigkeit sichergestellt, wie die Genauigkeit ...

Was ist das Problem mit Warteschlangen -Thread in Go's Crawler Colly? Was ist das Problem mit Warteschlangen -Thread in Go's Crawler Colly? Apr 02, 2025 pm 02:09 PM

Das Problem der Warteschlange Threading In Go Crawler Colly untersucht das Problem der Verwendung der Colly Crawler Library in Go -Sprache. Entwickler stoßen häufig auf Probleme mit Threads und Anfordern von Warteschlangen. � ...

Warum hat das Drucken von Saiten mit Println und String () -Funktionen unterschiedliche Effekte? Warum hat das Drucken von Saiten mit Println und String () -Funktionen unterschiedliche Effekte? Apr 02, 2025 pm 02:03 PM

Der Unterschied zwischen Stringdruck in GO -Sprache: Der Unterschied in der Wirkung der Verwendung von Println und String () ist in Go ...

Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Apr 02, 2025 pm 05:09 PM

Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Bei der Verwendung von Goland für GO -Sprachentwicklung begegnen viele Entwickler benutzerdefinierte Struktur -Tags ...

Wie löste ich das Problem des Typs des user_id -Typs bei der Verwendung von Redis -Stream, um Nachrichtenwarteschlangen in GO -Sprache zu implementieren? Wie löste ich das Problem des Typs des user_id -Typs bei der Verwendung von Redis -Stream, um Nachrichtenwarteschlangen in GO -Sprache zu implementieren? Apr 02, 2025 pm 04:54 PM

Das Problem der Verwendung von RETISTREAM zur Implementierung von Nachrichtenwarteschlangen in der GO -Sprache besteht darin, die Go -Sprache und Redis zu verwenden ...

Welche Bibliotheken in GO werden von großen Unternehmen entwickelt oder von bekannten Open-Source-Projekten bereitgestellt? Welche Bibliotheken in GO werden von großen Unternehmen entwickelt oder von bekannten Open-Source-Projekten bereitgestellt? Apr 02, 2025 pm 04:12 PM

Welche Bibliotheken in GO werden von großen Unternehmen oder bekannten Open-Source-Projekten entwickelt? Bei der Programmierung in Go begegnen Entwickler häufig auf einige häufige Bedürfnisse, ...

Was ist der Unterschied zwischen 'var' und 'Typ' Typenwort Definition in der GO -Sprache? Was ist der Unterschied zwischen 'var' und 'Typ' Typenwort Definition in der GO -Sprache? Apr 02, 2025 pm 12:57 PM

Zwei Möglichkeiten, Strukturen in der GO -Sprache zu definieren: Der Unterschied zwischen VAR- und Typ -Schlüsselwörtern. Bei der Definition von Strukturen sieht die Sprache oft zwei verschiedene Schreibweisen: Erstens ...

Wie kann sichergestellt werden, dass die Parallelität beim Schreiben von Multi-Process-Protokollen sicher und effizient ist? Wie kann sichergestellt werden, dass die Parallelität beim Schreiben von Multi-Process-Protokollen sicher und effizient ist? Apr 02, 2025 pm 03:51 PM

Effizient behandeln Probleme mit der Parallelitätssicherheit beim Schreiben von Multi-Process-Protokoll. Mehrere Prozesse schreiben gleichzeitig die gleiche Protokolldatei. Wie kann die Parallelität sicher und effizient sichergestellt werden? Das ist ein ...

See all articles