我在看wasmer go ext wasm example code/go-ext-wasm/wasmer/test/imports.go
了解如何设置上下文数据。我想将指针作为ContextData传递,最好的方法是什么?
//export sum
func sum(context unsafe.Pointer, x int32, y int32) int32 {
instanceContext := wasm.IntoInstanceContext(context)
t := *(*int)(instanceContext.Data())
log.Print("t: ", t)
return x + y
}
func testInstanceImport(t *testing.T) {
imports, err := wasm.NewImports().Namespace("env").Append("sum", sum, C.sum)
assert.NoError(t, err)
instance, err := wasm.NewInstanceWithImports(getImportedFunctionBytes("examples", "imported_function.wasm"), imports)
defer instance.Close()
assert.NoError(t, err)
bar := int(2)
barPtr := &bar
data := unsafe.Pointer(&bar)
instance.SetContextData(data)
log.Printf("bar %v, barPtr %v", bar, barPtr)
add1, exists := instance.Exports["add1"]
assert.Equal(t, true, exists)
result, err := add1(1, 2)
log.Print("Result: ", result)
assert.Equal(t, wasm.I32(4), result)
assert.NoError(t, err)
}
它为sum函数中的上下文提供预期值2。但是,当我将
data := unsafe.Pointer(&bar)
更改为data := unsafe.Pointer(&barPtr)
时,我会得到一个:runtime error: cgo argument has Go pointer to Go pointer
错误。当我用
GODEBUG=cgocheck=0
运行它时,它就工作了。我应该关注运行这个标志吗?我想做的是个坏主意吗?我有一个结构包含一个指针,我需要将其作为ContextData传递,使用GODEBUG=cgocheck=0
是一个坏主意吗?
最佳答案
我在这里找到了解决方案:cgo: Go pointers in Go memory
注册表示例(可选)解决了我的问题。谢谢。
关于go - 如何将go指针作为wasm上下文数据传递?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57542983/