我正在看wasmer go-ext-wasm示例代码/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)
}
哪给我求和函数中上下文的期望值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
是个坏主意吗?