我可以转换Go语言中从C(cgo)函数返回的字符串数组(char **)吗?
下面的代码可以编译并运行,但是我无法遍历字符串列表。
而且我什至不确定它是否违反了“传递指针”的规则:https://golang.org/cmd/cgo/
任何想法都将有所帮助,自从我用C编码已经有好几年了!提前致谢!
package main
/*
#include "stdlib.h"
char** getlist ()
{
char **array = NULL;
array = (char**)realloc(array, 2*sizeof(*array));
array[0]="HELLO";
array[1]="WORLD";
return array;
}
*/
import "C"
import (
"log"
"unsafe"
)
func main() {
list := C.getlist();
log.Printf("\n========\n C.getList()=%s", list)
ulist := unsafe.Pointer(list)
log.Printf("\n========\nulist=%s", ulist)
}
最佳答案
为了遍历Go中的字符串,您需要将数组转换为Go slice 。我们可以在这里跳过分配,然后直接进行转换(您的示例将长度静态设置为2,但实际上您可能会为此尺寸找到另一个来源)
cSlice := (*[1 << 28]*C.char)(unsafe.Pointer(list))[:2:2]
我们可以直接对此进行迭代,并使用
C.GoString
函数转换C字符串。这是比较安全的存储方式,因为它会将数据复制到Go内存中,但是如果该分片非常大,我们可以通过与上述相同的不安全转换来保存分配,尽管您首先需要找到每个字符串的长度。var slice []string
for _, s := range (*[1 << 28]*C.char)(unsafe.Pointer(list))[:2:2] {
slice = append(slice, C.GoString(s))
}
关于pointers - 从GO中的CGO转换字符串数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62012070/