ホームページ >バックエンド開発 >Golang >`defer` キーワードを使用して Go で関数の実行時間を測定するにはどうすればよいですか?

`defer` キーワードを使用して Go で関数の実行時間を測定するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-16 14:29:02353ブラウズ

How Can You Measure Function Runtime in Go Using the `defer` Keyword?

Go での関数のタイミングとランタイムの計算

Go では、時間パッケージを利用して関数のランタイムを正確に測定し、取得することができます。ミリ秒単位の値。便利なアプローチの 1 つは、遅延機能の使用です。

Go バージョン 1.x 以前では、次の関数を定義できます。

func trace(s string) (string, time.Time) {
    log.Println("START:", s)
    return s, time.Now()
}

func un(s string, startTime time.Time) {
    endTime := time.Now()
    log.Println("  END:", s, "ElapsedTime in seconds:", endTime.Sub(startTime))
}

コード内でこれらの関数を呼び出すことができます。次のように:

func someFunction() {
    defer un(trace("SOME_ARBITRARY_STRING_SO_YOU_CAN_KEEP_TRACK"))

    //do a bunch of stuff here...
}

defer ステートメントを利用することで、someFunction() の開始時に trace() 関数が呼び出されます。一方、un() 関数は延期され、someFunction() の完了後にのみ実行されます。このアプローチでは、コードの単純さを維持しながら、正確なランタイム ログが提供されます。

提供されたコード例ではログ ステートメントが使用されているため、ランタイム測定の精度にわずかに影響を与える可能性があることに注意してください。より高い精度が重要な場合は、ロギングのオーバーヘッドを最小限に抑える代替手法を試すことを検討してください。

以上が`defer` キーワードを使用して Go で関数の実行時間を測定するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。