Go 언어에서는 time 패키지의 Since() 함수를 사용하여 함수 실행 시간을 얻을 수 있습니다. 함수가 실행되기 전의 시작 시간을 설정하고, 시작 시간부터 함수 실행이 끝나는 현재까지의 시간 간격을 구합니다. 이 시간 간격은 함수 실행 시간이며 다음을 사용하여 계산할 수 있습니다. time.Since() 함수, "time.Since(t)" 구문은 t에서 지금까지 경과된 시간을 반환합니다.
이 튜토리얼의 운영 환경: Windows 7 시스템, GO 버전 1.18, Dell G3 컴퓨터.
시간을 사용하세요. 실행 시간을 계산하기 때문에
함수의 실행 시간의 길이는 이 함수의 성능을 측정하는 중요한 지표이며, 특히 비교 및 벤치마크 테스트에서 실행을 얻는 가장 쉬운 방법입니다. 함수 실행 시간 함수가 실행되기 전의 시작 시간을 설정하는 것으로, 시작 시간부터 함수 실행이 끝난 현재까지의 시간 간격을 구하는 것이 이 시간 간격이 함수의 실행 시간이다.
Go 언어에서는 time 패키지의 Since() 함수를 사용하여 함수의 실행 시간을 얻을 수 있습니다. 공식 Go 언어 문서에 있는 Since() 함수에 대한 소개는 다음과 같습니다.
func Since(t Time) Duration
Since() 함수는 t에서 지금까지 경과된 시간을 반환하며 이는 time.Now().Sub(t)와 동일합니다.
예제 1: Since() 함수를 사용하여 함수의 실행 시간을 가져옵니다.
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() }
실행 결과는 다음과 같습니다.
该函数执行完成耗时: 39.8933ms
위에서 time.Now().Sub() 함수가 있다고 언급했습니다. 이는 Since() 함수와 유사합니다. time.Now().Sub()를 사용하여 함수의 실행 시간을 얻으려면 위 코드의 14행만 수정하면 됩니다.
예 2: time.Now().Sub()를 사용하여 함수의 실행 시간을 가져옵니다.
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() }
실행 결과는 다음과 같습니다.
该函数执行完成耗时: 36.8769ms
컴퓨터 CPU 및 기타 요인의 영향으로 인해 , 함수의 실행 시간을 가져올 때 결과는 매번 약간씩 달라지며 이는 정상적인 현상입니다.
지식 확장: time.Now().Sub()를 사용하여 시차를 계산합니다.
다음과 같이 time.Since()를 time.Now().Sub()로 바꾸면 됩니다.
start := time.Now() // 获取当前时间 sum := 0 for i := 0; i < 100000000; i++ { sum++ } elapsed := time.Now().Sub(start) fmt.Println(elapsed)
실제로 time.Since는 내부적으로 Sub 함수를 호출하므로 time 패키지에 들어가 보겠습니다. 주석은 Since가 t 이후 경과된 시간을 반환한다는 의미입니다. .Sub(t),
srctimetime.go 923:6
// Since returns the time elapsed since t. // It is shorthand for time.Now().Sub(t). func Since(t Time) Duration { var now Time if t.wall&hasMonotonic != 0 { // Common case optimization: if t has monotonic time, then Sub will use only it. now = Time{hasMonotonic, runtimeNano() - startNano, nil} } else { now = Now() } return now.Sub(t) }
time.Now().Sub(start).Seconds()를 사용하여 경과된 초 수를 얻을 수도 있습니다. 경과한 시간 등을 얻으려면 해당 시간을 time.Since(start).Seconds(), time.Since(start).Seconds() 등으로 축약할 수도 있습니다.
【관련 추천: Go 비디오 튜토리얼, 프로그래밍 교육】
위 내용은 Go 언어에서 함수 실행 시간을 얻는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!