Cgo와 순수 Go 기능의 실행 시간을 반복적으로 비교하려고 시도한 테스터가 예상치 못한 결과를 만났습니다. . Cgo 함수는 Golang 함수보다 훨씬 오랜 시간이 걸려 테스트 코드에 대한 혼란과 탐색이 발생했습니다.
아래 제공된 테스트 코드는 Cgo의 실행 시간을 비교합니다. 및 순수 Go 기능은 각각 1억 번 실행되었습니다.
import ( "fmt" "time" ) /* #include <stdio.h> #include <stdlib.h> #include <string.h> void show() { } */ // #cgo LDFLAGS: -lstdc++ import "C" //import "fmt" func show() { } func main() { now := time.Now() for i := 0; i < 100000000; i = i + 1 { C.show() } end_time := time.Now() var dur_time time.Duration = end_time.Sub(now) var elapsed_min float64 = dur_time.Minutes() var elapsed_sec float64 = dur_time.Seconds() var elapsed_nano int64 = dur_time.Nanoseconds() fmt.Printf("cgo show function elasped %f minutes or \nelapsed %f seconds or \nelapsed %d nanoseconds\n", elapsed_min, elapsed_sec, elapsed_nano) now = time.Now() for i := 0; i < 100000000; i = i + 1 { show() } end_time = time.Now() dur_time = end_time.Sub(now) elapsed_min = dur_time.Minutes() elapsed_sec = dur_time.Seconds() elapsed_nano = dur_time.Nanoseconds() fmt.Printf("go show function elasped %f minutes or \nelapsed %f seconds or \nelapsed %d nanoseconds\n", elapsed_min, elapsed_sec, elapsed_nano) var input string fmt.Scanln(&input) }
테스트 코드 결과, C 함수 호출이 Go 함수에 비해 현저히 느린 것으로 나타났습니다. 이로 인해 테스트 코드 자체에 결함이 있는지에 대한 의문이 생겼습니다.
제공된 테스트 코드는 유효하지만 Cgo에 내재된 성능 제한으로 인해 Cgo 함수의 실행 시간이 느려졌습니다.
Cgo를 통해 C/C 코드를 호출하면 상대적으로 높은 오버헤드가 발생하고 이러한 CGo를 최소화합니다. 일반적으로 통화를 권장합니다. 이 특정 시나리오에서는 Go에서 CGo 함수를 반복적으로 호출하는 대신 루프를 C로 이동하면 잠재적으로 성능이 향상될 수 있습니다.
또한 CGo는 C 코드 실행을 위해 별도의 스레드 설정을 사용하여 코드의 내용에 대해 특정 가정을 합니다. 행동. 이러한 가정 중 일부는 성능에 영향을 미칠 수 있습니다.
CGo의 역할은 다음과 같습니다. 주로 기존 라이브러리와 인터페이스하기 위한 게이트웨이로 간주되며 잠재적으로 Go에서 수행되는 호출 수를 줄이기 위한 추가 작은 C 래퍼 기능이 있습니다. CGo를 통한 C와 유사한 성능 최적화에 대한 기대는 일반적으로 충족되지 않습니다. 이는 동등한 C 코드와 Go 코드 사이의 성능 격차가 이미 적기 때문입니다.
위 내용은 내 Cgo 기능이 동등한 Go 기능보다 훨씬 느린 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!