编译cgo软件包时,无法找到我的C标准库
我正在尝试编译一个覆盆子pi中的go项目。
该项目有5个文件,两个小型.c
文件及其对应文件.h
(其中一个文件是我的代码 - 它调用另一个,它是一个base64库)和一个.go
文件,它使用cgo
调用我的.c
代码。
当我只用gcc
单独编译我的C代码(包括其调用和所有内容)时,它在没有任何配置的情况下运行得很好。
当我使用go build
在我的x86
Linux Ubuntu机器上编译整个go项目时,它也相当不错。
但是,当我尝试去编译go项目, go build
在树莓派中go build
它时,它并没有得到我的C库:
fiatjaf@raspberrypi ~/g/s/b/f/project> go build -x
WORK=/tmp/go-build702187084
mkdir -p $WORK/bitbucket.org/fiatjaf/project/_obj/
cd /home/fiatjaf/go/src/bitbucket.org/fiatjaf/project
/usr/lib/go/pkg/tool/linux_arm/5c -FVw -I $WORK/bitbucket.org/fiatjaf/project/_obj/ -I /usr/lib/go/pkg/linux_arm -o $WORK/bitbucket.org/fiatjaf/project/_obj/base64.5 -DGOOS_linux -DGOARCH_arm ./base64.c
# bitbucket.org/fiatjaf/project
./base64.c:2 5c: No such file or directory: math.h
(如果我将<stdlib.h>
放在<math.h>
<stdlib.h>
之前,也会出现问题,所以问题不在于math.h的缺失,我认为)我试图:
// #cgo CFLAGS: -I/usr/include
到.go
文件 // #cgo LDFLAGS: -I/usr/include
(我无法发现这些标志的正确用法) go build -ldflags '-I/usr/include'
我不明白为什么要用-I /usr/lib/go/pkg/linux_arm
。 真的不要。 有人帮忙。
编辑:澄清有关项目结构的说明:
它有5个文件,2个C(及其对应的H):
base64.c
#include <math.h>
#include <stdint.h>
#include <stdlib.h>
... // definitions of functions used at project.c
project.c
#include <stdlib.h>
#include <string.h>
#include "base64.h"
... // functions used at project.go
和1去:
...
// #include <stdlib.h>
// #include <string.h>
// #include "project.h"
// #cgo CFLAGS: -I/usr/include
// #cgo LDFLAGS: -lm
import "C"
...
在这个声明中,什么以及如何改变这个东西的作用? 为什么它在我的x86 linux上运行?
cgo内联语法
go文件中cgo参数的正确语法如下:
// #cgo CFLAGS: -I/usr/include
没有#
和cgo
之间的空白。 有关语法的详细信息,请参阅cmd / cgo。
-ldflags参数
go -ldflags
参数将参数传递给连接器(5l,6l,8l,...)。 即使参数传递给C链接器,编译器也不会处理包含链接器的任何问题。
恐怕这个参数不会帮助你。 所有相关的参数都应该使用#cgo
标签在go源文件中进行配置。
杂项。 笔记
如果你使用math.h
你很可能需要链接libmath。 你可以通过将它写入你的源代码文件来做到这一点:
// #cgo LDFLAGS: -lm
看来我的问题与没有设置CGO_ENABLED
标志有关。
我不知道,但看起来,因为我从Raspbian存储库中卸载了我的Go(这似乎是默认禁用了CGO),并且从源代码安装了Go(就像我在x86 Linux中制作的那样),那么它开始工作。
链接地址: http://www.djcxy.com/p/74689.html上一篇: go build doesn't find my C standard library when compiling cgo package