PHP 편집자 Zimo는 cgo를 사용할 때 때때로 문제에 직면할 수 있다는 것을 발견했습니다. 즉 `__GI___pthread_mutex_unlock`이 실행 시간의 대부분을 차지한다는 것입니다. 이 문제는 성능 저하를 일으키고 프로그램의 실행 효율성에 영향을 미칠 수 있습니다. 이 문제를 해결하기 위해서는 `__GI___pthread_mutex_unlock`의 기능과 원리를 깊이 이해하고 그에 맞는 최적화 방법을 찾아야 합니다. 이 기사에서는 독자가 이 문제를 더 잘 이해하고 해결할 수 있도록 이 문제에 대한 자세한 분석을 제공할 것입니다.
go에서 c 함수를 호출하기 위해 cgo를 사용하고 있습니다. c 함수 내부에는 go 함수에 대한 콜백이 있습니다. 즉, go -> c ->
pprof를 실행한 후 __gi___pthread_mutex_unlock
가 실행 시간의 절반을 차지한다는 것을 알았습니다. Afaik, cgo에는 오버헤드가 있습니다. 특히 c에서 go로의 콜백이 있습니다. 그러나 이상하게도 cgo는 실행 시간의 절반을 잠금 작업에 소비합니다. 내 코드에 문제가 있나요?
main.go
callback.go
운영 환경:
lscpu
언어버전으로 가기
65bcae9650aa이것은 pprof 결과입니다:
EDIT: 런타임 환경 추가
위 프로그램으로는 재현할 수 없지만:
65bceaa20ecf하지만 각 콜백에는 전역 뮤텍스가 있으므로 병렬 콜백을 수행하면 성능이 저하됩니다.
위 내용은 go - `__GI___pthread_mutex_unlock`은 cgo를 사용할 때 실행 시간의 대부분을 차지합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!