这个问题的原因是:之前我们将编译完成的
.o
文件直接加入到了库的末尾,却并没有更新库的有效符号表。连接程序进行连接时,在静态库的符号索引表中无法定位刚才加入的
.o
文件中定义的函数或者变量。这就需要在完成库成员追加以后让加入的所有
.o
文件中定义的函数(变量)有效,完成这个工作需要使用另外一个工具“
ranlib
”来对静态库的符号索引表进行更新。
我们所使用到的静态库(文档文件)中,存在这样一个特殊的成员,它的名字是“
__.SYMDEF
”。它包含了静态库中所有成员所定义的有效符号(函数名、变量名)。因此,当为库增加了一个成员时,相应的就需要更新成员“
__.SYMDEF
”,否则所增加的成员中定义的所有的符号将无法被连接程序定位。完成更新的命令是:
ranlib
ARCHIVEFILE
通常在
Makefile
中我们可以这样来实现。
libfoo.a:
libfoo.a(x.o) libfoo.a(y.o) ...
ranlib libfoo.a
它所实现的是在更新静态库成员“
x.o
”和“
y.o
”之后,对静态库的成员“
__.SYMDEF
”进行更新(更新库的符号索引表)。
如果我们使用
GNU
ar
工具来维护、管理静态库,我们就不需要考虑这一步。
GNU
ar
本身已经提供了在更新库的同时更新符号索引表的功能(这是默认行为,也可以通过命令行选项控制
ar
的具体行为。可参考
GNU ar
工具的
man
手册)。
ranlib的用法!
ranlib的用法!
最新推荐文章于 2023-01-03 21:49:08 发布

静态库文件需要使用“
ar
”来创建和维护。当给静态库增建一个成员时(加入一个
.o
文件到静态库中),“
ar
”可直接将需要增加的
.o
文件简单的追加到静态库的末尾。之后当我们使用这个库进行连接生成可执行文件时,链接程序“
ld
”却提示错误,这可能是:主程序使用了之前加入到库中的
.o
文件中定义的一个函数或者全局变量,但连接程序无法找到这个函数或者变量。