cgo简单调用和引用动态库

本文介绍了如何使用cgo在Go程序中调用C编译的动态库。首先展示了C源代码和Go源代码的目录结构,然后详细阐述了C代码的编译过程,包括生成`.o`对象文件和`.so`动态库。在Go代码部分,演示了如何导入C代码并设置`pkg-config`路径及`LD_LIBRARY_PATH`。最后,文章提到了编译Go程序和运行结果,显示了C函数成功调用。
摘要由CSDN通过智能技术生成

cgo简单调用和引用动态库

1.目录结构
# c源代码目录结构

├── c-hello
│   ├── hi.c
│   ├── hi.h
│   ├── hi.o
│   └── libhi.so

# go源代码目录结构
go-hello
    ├── clib
    │   ├── include
    │   │   └── hi.h
    │   └── lib
    │       ├── libhi.so
    │       └── pkgconfig
    │           └── hi.pc
    └── main.go
2.c代码源码

(1.) hi.c 文件

/*
 * hi.c
 * created on: July 1, 2020
 *      author: tom
 */

#include <stdio.h>

void hi() {
    printf("Hello Cgo!\n");
}

(2.)hi.h 文件

void hi();

(3.)c代码编译成动态库

# 生成hi.o文件
gcc -c -fPIC -o hi.o hi.c

# 生成libhi.so动态库
gcc -shared -o libhi.so hi.o
3.go代码

(1.)main.go文件

package main

import "fmt"

/*
#cgo pkg-config: hi
#include "hi.h" //非标准c头文件,所以用引号
*/
import "C"

func main() {
    C.hi()
    fmt.Println("Hi, vim-go")
}

(2.)hi.pc文件

prefix=/xxx/go-hello/clib
exec_prefix=${prefix}
libdir=${exec_prefix}/lib
includedir=${exec_prefix}/include
Name: hi
Description: The hi library just for testing pkgconfig
Version: 0.1
Libs: -lhi -L${libdir}
Cflags: -I${includedir}

说明: hi.pc写完后,需要设置环境变量

# 设置pkg配置文件的路径,注意使用绝对路径
export PKG_CONFIG_PATH=/xxx/go-hello/clib/lib/pkgconfig:$PKG_CONFIG_PATH
# 查看库是否存在
echo $PKG_CONFIG_PATH
pkg-config --list-all | grep hi
# 设置lib库的路径,路径替换为自己的代码目录
export LD_LIBRARY_PATH=/xxx/go-hello/clib/lib:$LD_LIBRARY_PATH

(3.)go代码目录中其他文件
说明:hi.h文件拷贝自c代码,libhi.so文件来自于c代码生成的动态库文件,直接拷贝过来用。

4.编译运行
# 编译
go build main.go
# 运行
./main

# 输出结果:
Hello Cgo!
Hi, vim-go
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值