>백엔드 개발 >Golang >go - `__GI___pthread_mutex_unlock`은 cgo를 사용할 때 실행 시간의 대부분을 차지합니다.

go - `__GI___pthread_mutex_unlock`은 cgo를 사용할 때 실행 시간의 대부분을 차지합니다.

WBOY
WBOY앞으로
2024-02-10 09:45:08529검색

go - 使用 cgo 时,`__GI___pthread_mutex_unlock` 占用大部分执行时间

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

65bcae965051

callback.go

65bcae965088

운영 환경:

lscpu

65bcae965093

언어버전으로 가기

65bcae9650aa

이것은 pprof 결과입니다:

EDIT: 런타임 환경 추가

해결 방법

위 프로그램으로는 재현할 수 없지만:

65bceaa20ecf

하지만 각 콜백에는 전역 뮤텍스가 있으므로 병렬 콜백을 수행하면 성능이 저하됩니다.

위 내용은 go - `__GI___pthread_mutex_unlock`은 cgo를 사용할 때 실행 시간의 대부분을 차지합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제