新手向-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变量
相关推荐
匆匆那年9673 小时前
VSCode 远程 Linux 使用Codex
linux·ide·vscode
SWAGGY..4 小时前
Linux系统编程:(七)Makefile入门:轻松掌握编译自动化
linux·运维·自动化
开开心心就好5 小时前
免费流畅的远程控制实用工具
linux·运维·服务器·网络·智能手机·excel
黑猫学长呀6 小时前
存储宝典第2篇:盲封TT wafer是什么意思?
linux·嵌入式硬件·项目·芯片·ufs·晶圆·产测
Strugglingler7 小时前
【Linux 用户态操作 UART】
linux·uart
代码熬夜敲Q7 小时前
ENSP 网络工程实验
linux·运维·服务器
csdn_life187 小时前
OpenClaw v2026.5.12+ 高级密钥管理:使用SecretRef实现真正的隐蔽存储
linux·openclaw
Terrence Shen7 小时前
Claude Code Harness 源码学习讲义
linux·学习·ubuntu
赵药师7 小时前
dpkg: warning: files list file for package ‘libselinux1:amd64‘ missing;
linux·运维·服务器
STDD8 小时前
Samba 文件共享:Linux 服务器与 Windows/Mac 共享文件夹
linux·服务器·windows