如何通过CGO从C函数中的内部void*返回[]字节?

如何通过CGO从C函数中的内部void*返回[]字节?,go,cgo,Go,Cgo,我使用以下定义包装C函数: int parser_shift(parser* parser, void* buffer, int length); func (p *Parser) Shift() []byte { var buffer []byte // TODO: return buffer } 它从未解析字节的内部缓冲区中删除最长的字节,并将它们存储在给定的缓冲区中 现在,我希望将其包装为具有以下定义的Go函数: int parser_shift(parser

我使用以下定义包装C函数:

int parser_shift(parser* parser, void* buffer, int length);
func (p *Parser) Shift() []byte {
    var buffer []byte
    // TODO:

    return buffer
}
它从未解析字节的内部缓冲区中删除最长的字节,并将它们存储在给定的缓冲区中

现在,我希望将其包装为具有以下定义的Go函数:

int parser_shift(parser* parser, void* buffer, int length);
func (p *Parser) Shift() []byte {
    var buffer []byte
    // TODO:

    return buffer
}
用CGO完成上面的TODO,正确的写作方法是什么

我尝试了以下方法,但它因错误而崩溃:“/path/to/my/program”中的错误:free():无效的下一个大小(fast):0x00007f8fe0000aa0:

var buffer []byte
bufStr := C.CString(string(buffer))
defer C.free(unsafe.Pointer(bufStr))
C.parser_shift(p.Cparser, unsafe.Pointer(bufStr), C.int(8192))
buffer = []byte(C.GoString(bufStr))
return buffer

假设
parser\u shift
函数返回缓冲区中实际存储的字节数,则可以执行以下操作:

func (p *Parser) Shift() []byte {
    var buffer [8192]byte
    parsed := int(C.parser_shift(p.Cparser, unsafe.Pointer(&buffer[0]), C.int(len(buffer))))
    return buffer[:parsed]
}

无需将字符串转换为字符串或从字符串转换为字符串,只需将要写入的内存传递给它。

缓冲区是否为空?不应将字符串类型传递给c,请使用
c.CBytes()
,而不是创建
BufStr
并传递它。@nilsocket是的,你是对的,我不确定这是正确的写入方式。C函数通过void*buffer返回buffer,这是我希望接收的。谢谢!垃圾收集安全吗?buffer在Go GC控制下吗?只要你不保留它,它是安全的在你的C代码中有一个指向这个缓冲区的指针,你就不会有问题了。你的缓冲区在运行中,你只需要让C写一段时间就可以了。