>백엔드 개발 >Golang >Defer 기능을 사용하여 Go에서 함수 런타임을 측정하는 방법은 무엇입니까?

Defer 기능을 사용하여 Go에서 함수 런타임을 측정하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-17 09:12:03409검색

How to Measure Function Runtime in Go Using the Defer Feature?

Go에서 함수 런타임 측정

Go에서 함수의 실행 시간을 측정하는 간단한 방법은 defer를 활용하는 것입니다. 기능.

구현

  1. 다음 도우미 기능을 정의합니다.
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))
}
  1. 다음 기능을 사용하세요. 목표 함수:
func someFunction() {
    defer un(trace("SOME_ARBITRARY_STRING_SO_YOU_CAN_KEEP_TRACK"))

    // Perform the function's intended operations here...
}

설명

  • trace() 함수는 함수 시작 부분에서 호출되며 함수 이름과
  • defer un 문은 un()의 실행을 현재 시간이 끝날 때까지 연기합니다. 함수입니다.
  • un()이 실행되면 현재 시간과 Trace()에서 얻은 시작 시간의 차이를 이용하여 경과 시간을 계산합니다.
  • 시간이 로그인됩니다. 밀리초.

참고:

  • 이 접근 방식은 로깅 문으로 인해 원자 시계가 정확하지 않습니다. 보다 정확한 타이밍을 위해서는 특정 프로파일링 도구를 사용하는 것이 좋습니다.

위 내용은 Defer 기능을 사용하여 Go에서 함수 런타임을 측정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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