草庐IT

CGO_ENABLED

全部标签

在 CGO 中使用 C 结构的 golang 结构

我会用cgo封装一个c库作为项目使用的go库。看了文档,好像使用cgo有很多规则。我不知道这是否合法。LibCtx和Client都是C中的结构。将C结构放入golang结构是否合法?//DBClientLib.gotypeDBClientstruct{LibctxC.LibCtxLibClientC.Client}func(clientDBClient)GetEntry(keystring)interface{}{//...} 最佳答案 是的,这是完全合法的。看看这个简短的例子:packagemain/*typedefstructP

c - Golang cgo *C.int 大小差异

我正在探索CGO,我遇到了一个怪癖,在go运行时中C.int的大小是8个字节,但Cint是4个字节。我知道Goint可以是64位或32位,具体取决于体系结构,而Cint始终是32位。是有一种标准方法可以告诉go对C.int类型使用4个字节吗?我无法找到处理此问题的文档。因此,代码无法按预期运行。它基本上将低端添加到第一个int的高端。它从不引用传递的第二个int。提前致谢。实际输出:0xc00001a0b00xc00001a0b80xc00001a0b00xc00001a0b41990199主.gopackagemain/*intaddNums(int*nums);*/import"C

go - 如何在 cgo 导出函数中获取正确的参数名称?

我正在用Go编写一个库,我想导出到一个c-shared-library。它工作得很好,但是我发现导出的header使用p0、p1、p2、有点烦人……用于参数名称,而不是Go中的原始参数名称。有没有办法改变这种行为,或者我只是坚持这样做?Iamusinggoversiongo1.12.7darwin/amd64例子:packagemain/*#import*/import"C"import("fmt")funcmain(){}//exportMyFuncfuncMyFunc(input*C.char){fmt.Println(C.GoString(input));}gobuild-oli

docker - 二进制文件是用 'CGO_ENABLED=0' 编译的,go-sqlite3 需要 cgo 才能工作。这是一个 stub

我想在Golang项目中使用sqlite3。但是在docker容器中运行它有一些错误。二进制文件是用'CGO_ENABLED=0'编译的,go-sqlite3需要cgo才能工作。这是一个stub这是我的构建脚本CGO_ENABLED=0GOOS=linuxGOARCH=amd64gobuild-omainmain.go我不能在mac电脑上使用CGO_ENABLED=1FROMgolang:1.13-alpineENVWORK_DIR=/goENVTIME_ZONE=Asia/SingaporeRUNln-snf/usr/share/zoneinfo/$TIME_ZONE/etc/loc

windows - 转到异常 "signal arrived during cgo execution"

在什么情况下Go在调用dll时会出现“signalarrivedduringcgoexecution”之类的panic?要调用的代码是——基于go分发的src中的zsyscall_windows.go中的示例:var(//entrynamesfoundusingdumpbin/exportsdllSweph=syscall.NewLazyDLL("swedll32.dll")_swe_jdut1_to_utc=dllSweph.NewProc("_swe_jdut1_to_utc@36")_swe_julday=dllSweph.NewProc("_swe_julday@24"))fu

c++ - cgo : iostream:38:28: fatal error: bits/c++config. h 编译错误:没有那个文件或目录

我试图从thispage中的官方cudanvrtc指南执行saxpy示例它可以在终端上使用g++编译器并按照构建说明正常工作:g++saxpy.cpp-osaxpy-I$CUDA_PATH/include-L$CUDA_PATH/lib64-lnvrtc-lcuda-Wl,-rpath,$CUDA_PATH/lib64现在我正在尝试使用cgo工具以go语言执行它。我在“my_function”中命名了main函数,并试图用C.my_function调用它。这是我的cgo指令://PATH#cgoLDFLAGS:-L/usr/local/cuda-7.0/lib64-L/usr/loca

go - 将 cgo 数组转换为 slice

目前我这样做是为了将CGOdouble组转换为float64slice:doubleSlc:=[6]C.double{}//FilldoubleSlcfloatSlc:=[]float64{float64(doubleSlc[0]),float64(doubleSlc[1]),float64(doubleSlc[2]),float64(doubleSlc[3]),float64(doubleSlc[4]),float64(doubleSlc[5])}做同样的事情有没有更简单的方法?我想这也可以看作是在Go中不同类型的slice/数组之间进行转换的通用方法。

go - 用cgo编译出错

因此,我试图在不忙等待的情况下从stdin读取,忽略EOF,因为在我的案例中,客户端会来来去去。在C中,我会使用简单的select()或poll(),但我正在尝试学习Go,但我对缺少select()或poll()感到非常沮丧。我找不到在Go中使用select和channels的好方法,因为Read()将在EOF上立即返回,而我又回到了忙碌的等待状态。syscall.Select()似乎是最好的方法,但Go并没有费心去实现FD_SET!感叹所以,我正在尝试使用cgo。packagemain/*#include#includevoid_FD_SET(intsysfd,void*set){F

go - 如何在cgo中初始化空的C.CString

您认为在CGO中初始化长度为x的C.CString的最佳方法是什么?背景:我需要一个适当大小的char*作为C函数参数,但我想可以改进以下代码://length=6varbuffer[6]bytename:=C.CString(string(buffer[:6]))deferC.free(unsafe.Pointer(name))或//length=6name:=C.CString("")deferC.free(unsafe.Pointer(name)) 最佳答案 如果您不需要转换字符串,只需malloc您需要的大小即可:s:=C.

CGO 我正在传递一个 C 结构,它带有一个指向 go 函数的值的指针,

我很疑惑下面的场景是否需要清理内存?我有一个C函数,它创建一个C结构并将其传递给Go函数。C结构包含一个值数组(使用指针算法)。Go函数填充此数组并返回。在调用C函数中,我将值从C结构中复制出来并且不存储它们。因为这是在Go中创建的,所以垃圾会被收集吗?/*Ccode*/intgo_func(c_struct*s);structc_struct{val*values;size_t*values_cnt;};voidexample_call(){structc_structs;go_func(&s)copy_values(s)}/*gocode*/funcgo_func(c*C.c_st