我有一个C函数,它正在调用带有char数组参数的go-Function。go-Function必须修改参数的内容。如何做到这一点?
void cFunction() {
char buffer[9] = "aaabbbccc"; // 9 is in this case correct, it is not a null-terminated-string
goFunction(buffer);
// buffer shall be modified
}
func goFunction(cBuffer *C.char) {
// how to modify 3-5?
//strncpy(cBuffer+3, "XXX")
}
EDIT:更准确地说。我必须实现一个回调函数,它接受一个输出参数,我必须对其进行操作。
void callback(char outbuffer[9]) {
goFunction(outbuffer);
}
根据我对弗兰克的回答的理解,我应该这样做
allocate new go buffer
convert C buffer to go buffer
manipulate go buffer
allocate new C buffer
convert go buffer to C buffer
memcpy C buffer into outbuffer
这对我来说是太多的分配和转换
请参阅将C数组转换为Go切片的文档,以获得包含C数据的可索引Go切片。
因为您正在修改C缓冲区数据,使用Go片作为代理,所以您可以简单地将相同的缓冲区传递给回调。注意,使用append
可能会为您的切片分配一个新的Go数组,因此您需要避免它,并确保事先在缓冲区中有足够的可用空间。
func goFunction(cBuffer *C.char, length int) {
slice := (*[1 << 28]C.char)(unsafe.Pointer(cBuffer))[:length:length]
// slice can now be modified using Go syntax, without pointer arithmetic
C.callback(cBuffer)
}
不建议在Go语言中修改C语言结构体,也不建议在C语言中修改Go语言结构体。
一些特殊的函数通过复制数据在Go和C类型之间进行转换。在伪go定义中
>
> > >func char2Slice(data unsafe.Pointer, len C.int) []byte {
var value []byte
sH := (*reflect.SliceHeader)(unsafe.Pointer(&value))
sH.Cap, sH.Len, sH.Data = int(len), int(len), uintptr(data)
return value
}