밀리초 단위의 정밀도로 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!