백엔드 개발 Golang Golang을 사용한 벤치마크

Golang을 사용한 벤치마크

Sep 05, 2024 pm 09:31 PM

안녕하세요 고퍼스 여러분?

이 블로그 게시물에서는 #golang 테스트 패키지에 내장된 멋진 도구를 사용하는 방법을 보여 드리겠습니다. 코드 조각이나 함수의 성능을 어떻게 테스트하시겠습니까? 벤치마크 테스트

를 사용하세요.

가자.

이 테스트에서는 다음을 통해 결정되는 고전적인 피보나치 수열 또는 피보나치 수열을 사용합니다.

if (x < 2) 
   F(0) = 1
   F(2) = 2
else 
   F(x) = F(x-1) + F(x-2)

In practice, the sequence is:
1, 1, 2, 3, 5, 8, 13, etc.
로그인 후 복사

이 순서는 아래와 같이 수학과 자연의 여러 부분에도 나타나기 때문에 중요합니다.

Benchmark with Golang

이 코드를 구현하는 방법에는 여러 가지가 있으며 벤치마크 테스트를 위해 두 가지 방법, 즉 재귀적 계산 방법과 반복적 계산 방법을 선택하겠습니다. 함수의 주요 목적은 위치를 제공하고 해당 위치의 피보나치 수를 반환하는 것입니다.

재귀적 방법

// main.go

func fibRecursive(n int) int {
    if n <= 2 {
        return 1
    }
    return fibRecursive(n-1) + fibRecursive(n-2)
}
로그인 후 복사

반복 방법

// main.go

func fibIterative(position uint) uint {
    slc := make([]uint, position)
    slc[0] = 1
    slc[1] = 1

    if position <= 2 {
        return 1
    }

    var result, i uint
    for i = 2; i < position; i++ {
        result = slc[i-1] + slc[i-2]
        slc[i] = result
    }

    return result
}
로그인 후 복사

이러한 방법은 최적화되지 않았지만 소수의 경우에도 테스트 결과가 크게 다릅니다. 테스트에서 이를 확인할 수 있습니다. 코드를 따라가려면 여기를 클릭하세요.

이제 벤치마크 테스트를 위해 _main_test.go 파일에 몇 가지 테스트를 작성해 보겠습니다. benchmark에 대한 Golang 문서를 사용하면 다음과 같이 테스트할 함수를 생성할 수 있습니다.

// main_test.go

// The key is to start every function you want to benchmark with the keyword Benchmark and use b *testing.B instead of t *testing.T as input 
func BenchmarkFibIterative(b *testing.B) {
    // Use this for-loop to ensure the code will behave correctly. 
    // Now, you can put the function or piece of code you want to test
    for i := 0; i < b.N; i++ { 
        fibIterative(uint(100))
    }
}

// Same as above
func BenchmarkFibRecursive(b *testing.B) {
    for i := 0; i < b.N; i++ {
        fibRecursive(100)
    }
}
로그인 후 복사

계속하기 전에 질문: 어느 것이 더 빠릅니까?

작은 숫자(10)와 약간 큰 숫자(80)에 대해 테스트를 실행해 보겠습니다. 벤치마크 테스트를 실행하려면 다음 명령을 실행하면 됩니다.

테스트하기 -bench=함수 이름

이 명령에 대해 더 알고 싶다면 여기를 확인하세요.

첫 번째 테스트: 위치=10

//(fibIterative)
Results:
cpu: Intel(R) Core(TM) i7-7700HQ CPU @ 2.80GHz
BenchmarkFibIterative-8         24491042                42.50 ns/op
PASS
ok      playground      1.651s
로그인 후 복사

이 이미지를 활용하여 분석해 보겠습니다.

Benchmark with Golang

이미지에 따르면 테스트용 코어는 8개이며 시간 제한은 없습니다(완료될 때까지 실행됩니다). 작업을 완료하는 데 1.651초가 걸렸습니다.

==== Extra ====
We got 24,491,042 iterations (computations), and each iteration (op) took 42.50 ns.

Doing some math, we can calculate how much time one op took:

42.50 ns/op with 1 ns = 1/1,000,000,000 s
op ≈ 2.35270590588e-12 s
==== Extra ====
로그인 후 복사

좋은 결과네요. 위치 10에 대한 재귀 함수를 확인해 보겠습니다.

// Results
BenchmarkFibRecursive-8          6035011               187.8 ns/op
PASS
ok      playground      1.882s
로그인 후 복사

작업을 완료하는 데 1.882초가 걸렸음을 알 수 있습니다.

반복 함수가 몇 데시초 차이로 승리했습니다. 다음을 사용하여 한 번 더 테스트해 보겠습니다.

50위

// Results for the Iterative Function

cpu: Intel(R) Core(TM) i7-7700HQ CPU @ 2.80GHz
BenchmarkFibIterative-8         27896118                45.37 ns/op
PASS
ok      playground      2.876s

// Results for the Recursive Function

cpu: Intel(R) Core(TM) i7-7700HQ CPU @ 2.80GHz
BenchmarkFibRecursive-8          6365198               186.3 ns/op
PASS
ok      playground      1.918s
로그인 후 복사

와! 이제 재귀함수가 빨라지나요?

조금 더 큰 숫자로 마무리하겠습니다.

80위

// Results for the Iterative Function

cpu: Intel(R) Core(TM) i7-7700HQ CPU @ 2.80GHz
BenchmarkFibIterative-8          5102344               229.5 ns/op
PASS
ok      playground      1.933s

// Results for the Recursive Function
// My poor PC couldn’t handle it, so I had to reduce the position to 50 just to get some results printed.

cpu: Intel(R) Core(TM) i7-7700HQ CPU @ 2.80GHz
BenchmarkFibRecursive-8                1        44319299474 ns/op
PASS
ok      playground      44.951s
로그인 후 복사

차이가 엄청납니다. 위치 80의 경우 반복 접근 방식은 약 2초가 소요되었습니다. 50 위치의 경우 재귀 함수에 약 45초가 걸렸습니다. 이는 Golang 프로젝트 속도가 느려지기 시작할 때 코드 벤치마킹의 중요성을 보여줍니다.

결론

프로덕션 코드가 느리게 실행되거나 예측할 수 없을 정도로 느린 경우 pprof 또는 내장 테스트 패키지의 다른 도구와 함께 이 기술을 사용하여 코드가 수행되는 위치를 식별하고 테스트할 수 있습니다. 열악한 부분과 이를 최적화하는 방법.

참고: 눈에 아름다운 코드가 모두 성능이 뛰어난 것은 아닙니다.

추가 운동

재귀 기능을 개선할 수 있는 더 좋은 방법을 찾을 수 있나요? (팁: 동적 프로그래밍을 사용하세요). 이 문서에서는 일부 작은 숫자의 경우 재귀 전략이 더 나은 이유를 설명합니다.

위 내용은 Golang을 사용한 벤치마크의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

<gum> : Bubble Gum Simulator Infinity- 로얄 키를 얻고 사용하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Nordhold : Fusion System, 설명
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora : 마녀 트리의 속삭임 - Grappling Hook 잠금 해제 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Golang vs. Python : 성능 및 확장 성 Golang vs. Python : 성능 및 확장 성 Apr 19, 2025 am 12:18 AM

Golang은 성능과 확장 성 측면에서 Python보다 낫습니다. 1) Golang의 컴파일 유형 특성과 효율적인 동시성 모델은 높은 동시성 시나리오에서 잘 수행합니다. 2) 해석 된 언어로서 파이썬은 천천히 실행되지만 Cython과 같은 도구를 통해 성능을 최적화 할 수 있습니다.

Golang 및 C : 동시성 대 원시 속도 Golang 및 C : 동시성 대 원시 속도 Apr 21, 2025 am 12:16 AM

Golang은 동시성에서 C보다 낫고 C는 원시 속도에서 Golang보다 낫습니다. 1) Golang은 Goroutine 및 Channel을 통해 효율적인 동시성을 달성하며, 이는 많은 동시 작업을 처리하는 데 적합합니다. 2) C 컴파일러 최적화 및 표준 라이브러리를 통해 하드웨어에 가까운 고성능을 제공하며 극도의 최적화가 필요한 애플리케이션에 적합합니다.

GOT GO로 시작 : 초보자 가이드 GOT GO로 시작 : 초보자 가이드 Apr 26, 2025 am 12:21 AM

goisidealforbeginnersandsuitableforcloudandnetworkservicesduetoitssimplicity, 효율성, 및 콘크리 론 피처

Golang vs. C : 성능 및 속도 비교 Golang vs. C : 성능 및 속도 비교 Apr 21, 2025 am 12:13 AM

Golang은 빠른 개발 및 동시 시나리오에 적합하며 C는 극도의 성능 및 저수준 제어가 필요한 시나리오에 적합합니다. 1) Golang은 쓰레기 수집 및 동시성 메커니즘을 통해 성능을 향상시키고, 고전성 웹 서비스 개발에 적합합니다. 2) C는 수동 메모리 관리 및 컴파일러 최적화를 통해 궁극적 인 성능을 달성하며 임베디드 시스템 개발에 적합합니다.

Golang vs. Python : 주요 차이점과 유사성 Golang vs. Python : 주요 차이점과 유사성 Apr 17, 2025 am 12:15 AM

Golang과 Python은 각각 고유 한 장점이 있습니다. Golang은 고성능 및 동시 프로그래밍에 적합하지만 Python은 데이터 과학 및 웹 개발에 적합합니다. Golang은 동시성 모델과 효율적인 성능으로 유명하며 Python은 간결한 구문 및 풍부한 라이브러리 생태계로 유명합니다.

Golang 및 C : 성능 상충 Golang 및 C : 성능 상충 Apr 17, 2025 am 12:18 AM

Golang과 C의 성능 차이는 주로 메모리 관리, 컴파일 최적화 및 런타임 효율에 반영됩니다. 1) Golang의 쓰레기 수집 메커니즘은 편리하지만 성능에 영향을 줄 수 있습니다. 2) C의 수동 메모리 관리 및 컴파일러 최적화는 재귀 컴퓨팅에서 더 효율적입니다.

공연 경주 : 골랑 대 c 공연 경주 : 골랑 대 c Apr 16, 2025 am 12:07 AM

Golang과 C는 각각 공연 경쟁에서 고유 한 장점을 가지고 있습니다. 1) Golang은 높은 동시성과 빠른 발전에 적합하며 2) C는 더 높은 성능과 세밀한 제어를 제공합니다. 선택은 프로젝트 요구 사항 및 팀 기술 스택을 기반으로해야합니다.

Golang vs. Python : 장단점 Golang vs. Python : 장단점 Apr 21, 2025 am 12:17 AM

golangisidealforbuildingscalablesystemsdueToitsefficiencyandconcurrency

See all articles