cgo를 사용하여 C 코드에 함수 포인터 전달
Go v1.6부터 cgo는 C 코드에 포인터를 전달하는 규칙을 변경했습니다. Go wiki에 설명된 대로 C 코드에서 동적 Go 콜백을 호출하는 이전 방법은 더 이상 작동하지 않습니다.
cgo의 새 규칙
cgo는 이제 Go 포인터 전달을 금지합니다. 그들이 참조하는 메모리에 Go 포인터 자체가 포함되어 있으면 C로 변경됩니다. 이 제한은 런타임에 적용되므로 위반할 경우 프로그램 충돌이 발생합니다.
한계 극복
새로운 제한에도 불구하고 포인터를 C 코드로 전송하는 방법에는 여러 가지가 있습니다. 부과된 규칙을 준수하면서. 일반적인 접근 방식 중 하나는 고유 ID와 실제 포인터를 매핑하는 동기화된 데이터 구조를 저장하는 것입니다. 이를 통해 직접 포인터 대신 ID를 C 코드로 전송할 수 있습니다.
코드 솔루션
다음 코드 조각은 문제에 대한 솔루션을 보여줍니다.
<code class="go">package main import ( "fmt" "sync" ) // Declare a function to be invoked by C code. func MyCallback(x int) { fmt.Println("callback with", x) } func Example() { i := register(MyCallback) // Register the callback function and obtain its ID. C.CallMyFunction(C.int(i)) // Pass the ID to the C function. unregister(i) // Deregister the callback function. } // Data structures for registering and deregistering callbacks. var mu sync.Mutex var index int var fns = make(map[int]func(int)) // Register a callback function and return its ID. func register(fn func(int)) int { mu.Lock() defer mu.Unlock() index++ for fns[index] != nil { index++ } fns[index] = fn return index } // Return the callback function associated with a given ID. func lookup(i int) func(int) { mu.Lock() defer mu.Unlock() return fns[i] } // Deregister a callback function using its ID. func unregister(i int) { mu.Lock() defer mu.Unlock() delete(fns, i) } func main() { Example() }</code>
이 코드는 Wiki 페이지의 업데이트된 지침에 부합하며 새로운 cgo 규칙에 따라 C 코드에 함수 포인터를 전달하는 실행 가능한 솔루션을 제공합니다.
위 내용은 Go v1.6의 변경 후 cgo를 사용하여 Go의 C 코드에 함수 포인터를 전달하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!