CGO를 사용하여 C 코드에 함수 포인터 전달
소개
In Go 이전 버전 1.6에서는 CGO를 사용하여 C 코드에 함수 포인터를 전달하는 것이 간단했습니다. 그러나 Go 1.6에 새로운 규칙이 도입되면서 이 관행은 더욱 복잡해졌습니다.
문제
문제의 핵심은 업데이트된 CGO 규칙에 있습니다. 이는 Go 코드가 참조하는 메모리에 다른 Go 포인터가 포함되어 있지 않은 경우에만 Go 코드가 C에 Go 포인터를 전달할 수 있다고 규정합니다. 함수 포인터가 다른 Go 포인터를 포함할 수 있는 Go 메모리에 저장되기 때문에 이로 인해 문제가 발생합니다.
잠재적 솔루션
이 문제를 해결하기 위한 여러 가지 접근 방식이 등장했습니다. 일반적인 해결책 중 하나는 직접 함수 포인터의 사용을 완전히 포기하는 것입니다. 대신, ID(정수)를 실제 함수 포인터에 매핑하는 동기화된 데이터 구조를 만드세요. 이를 통해 포인터 자체 대신 ID를 C 코드에 전달할 수 있습니다.
구현 예
다음 코드 조각은 이 접근 방식을 구현하는 방법을 보여줍니다.
<code class="golang">package gocallback import ( "fmt" "sync" ) type Callback func(C.int) var mu sync.Mutex var index int var fns = make(map[int]Callback) func register(fn Callback) int { mu.Lock() defer mu.Unlock() index++ for fns[index] != nil { index++ } fns[index] = fn return index } func lookup(i int) Callback { mu.Lock() defer mu.Unlock() return fns[i] } func unregister(i int) { mu.Lock() defer mu.Unlock() delete(fns, i) }</code>
C 코드에서의 사용법
Go 데이터 구조가 마련되면 함수 포인터 대신 ID를 전달하여 C 코드에서 Go 콜백을 호출할 수 있습니다. 그 자체. 예:
<code class="c">extern void go_callback_int(int foo, int p1); static inline void CallMyFunction(int foo) { go_callback_int(foo, 5); }</code>
결론
새로운 CGO 규칙은 함수 포인터를 C 코드에 전달하는 프로세스에 약간의 복잡성을 추가하지만 이 문서에 설명된 접근 방식은 다음과 같습니다. 효과적인 솔루션을 제공합니다. 동기화된 데이터 구조와 ID를 활용하면 최신 CGO 규정을 준수하면서 Go와 C 코드 간 인터페이스의 이점을 계속 누릴 수 있습니다.
위 내용은 Go 버전 1.6 이상에서 CGO를 사용하여 C 코드에 함수 포인터를 전달할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!