gcc 链接顺序,静态库循环依赖问题

链接过程由链接器 ld 负责。通常 GCC 间接驱动之。

越底层的库,在链接命令行中的位置应越靠后。

文章目录

链接过程

.o 目标文件(Object File)

.a 静态库(Static Library)是多个.o的集合

导出符号:.当前编译单元 .o /.a 定义的、可供其他编译单元使用的符号

导入符号:需要导入,但没找到的符号

符号:

函数声明 与 函数实现

全局变量

局部静态变量

这些需要全局使用,所以进程地址空间有个数据段,代码段。

符号表在链接时用来做这些准备~

链接器ld维护两个符号表:

  • 已决符号表A: 遇到的所有.o/.a的导出符号
  • 未决符号表B: 遇到的所有.o/.a需要导入,但尚未找到的符号

链接器对一个 .o 文件的每个符号:

  • 导出符号 加入到 已决符号表A ,若 未决符号表B 存在该符号,则删除。
    若 已决符号表A 已存在该符号,则报错"多重定义"
  • 导入符号 若 已决符号表A 不存在该符号,则添加到表B

※ 但是对于静态库,链接器仅提取当前未解析符号所需的对象文件,未使用的对象文件会被丢弃。

所以:

静态库(.a)需要在使用它的目标文件之后

(原因见上)

复制代码
g++ main.o -lprotobuf -o client.out

循环依赖的静态库

(原因见上)

如果 libA.a 依赖 libB.a 里的符号,而 libB.a 也依赖 libA.a

复制代码
g++ main.o -lA -lB -lA -o myapp

这样 libA.a 会被解析两遍,确保所有符号都能找到。

相关推荐
北塔软件3 分钟前
北塔软件智能体平台 | 不只监控,更是AI时代的数据资产
运维·人工智能·知识库·北塔软件
zhangfeng113321 分钟前
ps aux讲解,结合国家超算中心 hpc apptainer
linux·服务器·网络
夜月yeyue26 分钟前
STM32 DMA 双缓冲采样
linux·stm32·单片机·嵌入式硬件·系统架构
ScilogyHunter27 分钟前
Buildroot完全指南:从入门到实战
linux·嵌入式·buildroot
毕竟是shy哥35 分钟前
Claude Code 接入 DeepSeek 保姆级教程,WSL/Linux 通用
linux·安装教程·codex·deepseek·claude code·openclaw
AOwhisky44 分钟前
学习自测与解析:MySQL第五、六、七期核心知识点详解
运维·数据库·笔记·学习·mysql·云计算
无限进步_1 小时前
从零实现一个迷你Shell——深入理解Linux命令行解释器
linux·运维·服务器·开发语言·c++·chrome
阿标在干嘛1 小时前
政策平台的推送系统:消息队列、定时任务、AB测试的工程实践
服务器·数据库·ab测试
Adorable老犀牛1 小时前
nginx_exporter:Prometheus 监控 Nginx 基础指标
运维·nginx·prometheus
山里幽默的程序员1 小时前
DevOps 必备:盘点2026 年最强RESTful API 接口测试方案
运维·restful·devops·api开发·api开发工具