>백엔드 개발 >Golang >Go에서 밀리초 단위의 정밀도로 함수 실행 시간을 효율적으로 측정하려면 어떻게 해야 합니까?

Go에서 밀리초 단위의 정밀도로 함수 실행 시간을 효율적으로 측정하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-12 05:22:02262검색

How can I efficiently measure function execution time in Go with millisecond precision?

밀리초 단위의 정밀도로 Go에서 함수 실행 시간 측정

Go의 과제 중 하나는 함수의 런타임을 결정하고 이를 보고하는 것입니다. 밀리초.

해결책: Go 활용 defer

Go의 defer 문은 타이밍 기능에 대한 편리한 솔루션을 제공합니다. 달성 방법은 다음과 같습니다.

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))
}

2단계: 기능 시간 측정

시간에 맞춰 someFunction이라는 함수를 만들고 다음과 같이 Trace() 및 un() 호출로 래핑합니다.

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

    // Do your function logic here
}

설명

trace() 함수는 다음에서 호출됩니다. 기능의 시작, 시작 시간을 기록합니다. un() 함수는 함수의 끝으로 연기되어 경과 시간을 측정하고 이를 밀리초 단위의 정밀도로 로그에 인쇄합니다.

시간 측정 사용자 정의

이것은 endTime.Sub(startTime)을 조정하여 나노초 또는 마이크로초와 같은 다른 시간 단위를 측정하도록 기술을 수정할 수 있습니다.

Go의 defer 문을 활용하면 함수 실행 시간을 밀리초 단위로 쉽고 정확하게 측정할 수 있어 성능 최적화를 위한 귀중한 통찰력을 얻을 수 있습니다.

위 내용은 Go에서 밀리초 단위의 정밀도로 함수 실행 시간을 효율적으로 측정하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.