新手向-pkg-config的原理和使用

工作中遇到,发现自己不太了解,所以写篇博客学习&记录一下,不同意见欢迎评论区分享。


1. 简介

pkg-config是一个用于链接库的工具,可以简化编译的语句。

以编译需要opencv的代码为例:

bash 复制代码
# 不使用pkg-config
g++ -o opencv opencv.cpp  -L/usr/local/lib -lopencv_highgui -lopencv_ml -lopencv_objdetect -lopencv_photo -lopencv_stitching -lopencv_video -lopencv_calib3d -lopencv_features2d -lopencv_dnn -lopencv_flann -lopencv_videoio -lopencv_imgcodecs -lopencv_imgproc -lopencv_core

# 使用pkg-config
g++ -o opencv opencv.cpp `pkg-config --cflags --libs opencv4`  

pkg-config帮我们自动链接了opencv相关的库,省得我们自己写了。

2. 原理

pkg-config的原理是应用在装包时提供一个pc文件,存在在指定的目录。

这个pc文件里通常包含使用这个库需要的库路径,以及头文件路径等内容。

编译的时候pkg-config会自动到目录下寻找相应的pc文件,按找文件的内容链接头文件和库文件。

3. pc文件

用一个简单的示例来解释pc文件的内容:

bash 复制代码
# 文件名叫mylib.pc
prefix=/usr/local                # 安装的根路径,通常mylib的所有文件都在这个路径下
exec_prefix=${prefix}            # 专门用于存放可执行文件和相关资源的目录                               
includedir=${prefix}/include     # 头文件目录
libdir=${exec_prefix}/lib        # 库文件目录

# 开发者可以在 .pc 文件中定义任何变量,没有限制,举例的以上4个是较为常用的

Name: MyLibrary                  # 包的名称
Description: A sample library for demonstration # 包的描述
Version: 1.0.0                   # 包的版本
Requires: libxml-2.0 >= 2.4.0    # 依赖的包
Requires.private: zlib >= 1.2.8  # 私有依赖的包(静态链接需要的)
Conflicts: mylib-old <= 0.9      # 冲突的包
Cflags: -I${includedir}/mylib    # 编译标志(通常是头文件路径)
Libs: -L${libdir} -lmylib        # 链接标志(通常是库路径和库名)
Libs.private: -lm                # 私有链接标志(静态链接时需要)

这个文件需要放置在指定路径下才能生效,可以通过指令查询生效路径:

bash 复制代码
# 查询pkg-config的pc文件存放路径
pkg-config --variable=pc_path pkg-config

如果要在编译时使用此pc文件,编译语句应该为:

bash 复制代码
gcc -o demo demo.c `pkg-config --cflags --libs mylib` 
# 这里是pc文件名,不是文件里的包名
# --cflags --libs 表示使用文件里的Cflags变量和Libs变量
相关推荐
倔强的石头1066 小时前
【Linux指南】基础IO系列(八):实战衔接 —— 给微型 Shell 添加完整重定向功能
linux·运维·服务器
try2find6 小时前
打印ascii码报错问题
java·linux·前端
Ujimatsu6 小时前
虚拟机安装Ubuntu 26.04.x及其常用软件(2026.4)
linux·运维·ubuntu
一直会游泳的小猫9 小时前
homebrew
linux·mac·工具·包管理
寒秋花开曾相惜9 小时前
(学习笔记)4.2 逻辑设计和硬件控制语言HCL(4.2.1 逻辑门&4.2.2 组合电路和HCL布尔表达式)
linux·网络·数据结构·笔记·学习·fpga开发
狂奔的sherry9 小时前
一次由 mount 引发的 Linux 文件系统“错觉”
linux·运维·服务器
小黑要努力9 小时前
智能音箱遇到的问题(一)
linux·运维·git
ch3nyuyu10 小时前
静态库和动态库的制作
linux·运维·开发语言
一口Linux10 小时前
Linux C编程 | 从0实现telnet获取程序终端控制权
linux·运维·c语言
willhuo10 小时前
Certbot工具在CentOS 7.9上申请和配置SSL证书完整教程
linux·centos·ssl