草庐IT

cgo_unix

全部标签

macos - OS X 10.9 中的 Golang : CGO_ENABLED=0 GOOS=linux GOARCH=arm ERROR

cd/usr/local/go/srcCGO_ENABLED=0GOOS=linuxGOARCH=arm./make.bash#BuildingCbootstraptool.cmd/dist#BuildingcompilersandGobootstraptoolforhost,darwin/amd64.lib9libbiolibmachmisc/pprofcmd/addr2linecmd/covcmd/nmcmd/objdumpcmd/packcmd/profcmd/cccmd/gccmd/6lcmd/5l/usr/local/go/src/cmd/5l/../ld/lib.c:661

linux - 在 Windows 中使用 Golang 中的 SCP 复制远程 unix 主机中的远程文件

需要将linux服务器中的远程文件复制到windows本地服务器,我想知道是否可以使用golang(是否使用标准库,并且该进程将在windows上运行)来完成此任务,或者甚至可以调用另一个进程,如winscp。 最佳答案 有两种方法可以解决这个问题:使用库执行SCP协议(protocol)。golang中没有任何用于SCP协议(protocol)的标准库。但是你可以使用thisSCP协议(protocol)库。使用操作系统二进制执行SCP协议(protocol)。但请记住,在这种情况下,您的程序只能在安装了此特定操作系统二进制文件的

go模块没有正确下载动态库的cgo软链接(soft link)

环境为ubuntu16.0464bit,go版本go1.12linux/amd64我正在尝试将我的golang项目从gopath切换到gomodule。我项目导入的包之一是使用cgo调用ffmpeg,包中有几个动态的ffmpeg库,例如libavcodec.so,libavcodec.so.57,libavcodec.so.57.1​​07.100,前两个文件是软链接(softlink)文件问题是当我去构建我的golang项目时,go模块只下载libavcodec.so.57.1​​07.100,它没有下载两个软链接(softlink)文件我尝试去获取包,并成功获取了包括软链接(sof

c++ - Cgo 找不到像 <iostream> 这样的标准库

我试图在我的Go代码中包含C++代码,但无法识别。我首先认为它认为它是C代码并尝试(并失败)编译这样,但删除包含行实际上给了我这样的C++错误故障排除error:‘cout’isnotamemberof‘std’代码使用g++正确编译。我尝试添加-lstdc++LDLFLAG,并在CXXFLAG中添加库的路径,但它没有改变任何东西。我做了一些其他测试(但都失败了),但这是最小的一个。这是c++文件test.cpp#include"test.hpp"inttest(){std::coutinttest();这是我的go文件//#cgoCXXFLAGS:-I/usr/lib///#cgoL

go - 在 go 项目中使用 cgo 包含 libsodium 失败

我正在尝试包含libsodium进入我的Go项目。为此,我在我的项目中复制了repo//#cgoCFLAGS:-I/mypath/libsodium/src/libsodium/include/sodium//#include//#include"crypto_sign_ed25519.h"import"C"尝试构建项目时出现以下错误:/tmp/go-build/cgo-gcc-prolog:53:undefinedreferenceto`crypto_sign_ed25519_pk_to_curve25519'collect2:error:ldreturned1exitstatus可

unix - 如何将命令行选项传递给我的 dockerized GoLang 程序?

我有一个简单的dockerizedgolang程序,我希望能够在运行容器时向它发送命令行选项。我的Dockerfile如下所示:FROMgolang:onbuildRUNgoget[MYPROGRAM] 最佳答案 只要您的应用按照Go约定编译为单个二进制文件,您就应该能够使用下面这个简单的两行代码,在ENTRYPOINT指令中将任何后续标志作为类似数组的参数传递。FROMgolang:onbuildENTRYPOINT["/go/bin/app","-name=foo","-title=bar"]

unix - log15 库将纪元时间从纳秒舍入到秒以进行日志记录

我希望我的golang项目中的日志记录具有毫秒级的精度,目前使用的是log15库问题是当我将它附加到Context时,它四舍五入到秒newTimeWithMilliseconds:=time.Unix(0,time.Now().UnixNano())returnlog.FuncHandler(func(r*log.Record){r.Ctx=append(r.Ctx,"time",newTimeWithMilliseconds)nextHandler.Log(r)})当我将它转换为字符串newTimeWithMilliseconds.String()时,它起作用了,我得到了"2018-

go - Unix 时间在 GOLANG 中返回 0 或某个小值

下面的GO代码有什么问题?我尝试了一个GO项目并部署在Openshift中,直到昨天一切都很好。突然从今天开始,时间包返回0val,_:=strconv.ParseInt(string(time.Now().Unix()),10,64)println("Timenowinopenshift:",time.Now().Second())所以基本上这里的实际时间是“1969-12-31”。可能是GO中的错误。 最佳答案 绝对没有必要手动将时间转换为字符串,time.Format会为您完成这项工作。或者,如果您想打印出纪元以来的秒数,只需

golang(cgo) --- 不确定 C.quit 的名称类型

没有任何错误,但是“notdeterminekindofnameforC.quit”我在我的项目中将共享库与#cgoLDFLAGS链接在一起。可能的原因是什么? 最佳答案 我使用了'quit'函数(一个粗心的错误),但是在C代码中没有这个函数。 关于golang(cgo)---不确定C.quit的名称类型,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/38351486/

google-app-engine - Go: install drive v2 package cmd/cgo 报错

我正在尝试获取googledrivepackageforgo,但使用下面的总是会引发错误。我应该手动安装吗?./gogetcode.google.com/p/google-api-go-client/drive/v2loadcmd/cgo:packagecmd/cgo:noGosourcefilesin.../google_appengine/goroot/src/cmd/cgo 最佳答案 包裹好像坏了。其导入路径(v2)的基本名称与在那里找到的包名称(drive)不匹配。我不确定,但我想也许生成某些内容的某些脚本已损坏。我建议询问