草庐IT

cgo_unix

全部标签

c - 通过Cgo访问aerospike C客户端报错

我正在尝试学习Cgo,所以我尝试从Cgo访问aerospike客户端packagemain//#cgoCFLAGS:-g-Wall//#include//#include//#include"aerospike-client-c/examples/put/example_utils.h"import"C"import("unsafe")funcmain(){retvals:=C.putitnew()_=retvals}但我遇到以下错误。(请注意,当我执行make和makerun时,C程序运行成功)。undefinedreferenceto`example_get_opts'./aero

go - 你如何使用cgo静态链接一个c库?

因此小组中有很多建议您可以在go中执行此操作(尽管cgo文档中没有):packagebridgeimport"fmt"//#cgoCFLAGS:-I/Users/doug/projects/c/go-bridge/include//#cgoLDFLAGS:/Users/doug/projects/c/go-bridge/build/libgb.a//#includeimport"C"funcRun(){fmt.Printf("Invokingclibrary...\n")C.x(10)fmt.Printf("Done\n")}然而,它似乎不起作用:/var/folders/.../br

c++ - Cgo 生成的源代码无法在 MVC 上编译

我有一个用CGo制作的共享库,它在Linux和Android上链接良好。但是当使用MicrosoftVisualStudio2017在Windows10上编译时,出现以下错误:Microsoft(R)ProgramMaintenanceUtilityVersion14.16.27024.1Copyright(C)MicrosoftCorporation.Allrightsreserved.cl-c-nologo-Zc:wchar_t-FS-Zc:rvalueCast-Zc:inline-Zc:strictStrings-Zc:throwingNew-Zc:referenceBindin

在 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

unix - go语言os.FileMode函数是如何从integers/octal/转换权限的???在设置标志之前?

更新:根据目前的评论和回复,我想我应该明确表示我理解0700是十进制数448的八进制表示。我关心的是当一个八进制mode参数,或者当一个十进制数被重铸为八进制数并传递给os.FileMode方法时,使用WriteFile创建的文件的最终权限似乎没有以一种有意义的方式排列。我尽我所能将问题的规模缩小到本质,也许我需要再做一轮Update2:重新阅读后,我想我可以更简洁地陈述我的问题。调用os.FileMode(700)应该与使用二进制值1-010-111-100调用它相同。对于这9个最低有效位,应该有以下权限:--w-rwxr--或八进制的274(并转换回相反,FileMode导致Wri

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

time - 在 Go 中获取 Unix 时间戳的正确方法是什么

在Go中获取Unix时间戳的正确方法是什么?我以为它会是time.Now().Unix()但显然不是。http://play.golang.org/p/KoJADUDxOStime.Now().Unix()告诉我unix时间戳是1257894000而我的浏览器告诉我它是1398351437。www.unixtimestamp.de还告诉我它是1398351704,这是我所期望的。为什么来自Go的那个这么远?顺便说一句,我在本地机器上得到了相同的结果。我错过了什么?更新好吧,事实证明这真的只是play.golang.org上的一个问题。我以为我也在本地测试过它,但我现在又看了一眼,是的,

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