【问题描述】
有两个静态库 libA.a 和 libB.a,libB.a 把 libA.a 包括在其中。
在build libB.a的过程中遇到 link error,编译器报错说有函数找不到实现。
【原因】
这里的做法不正确:build libB.a 的过程中,先编译 libB 自己的源文件,编译得到的 .o 文件放到 obj 文件夹下,然后将 libA.a 打散还原成原先的各个 .o 文件,将它们也放到 obj 文件夹下。由于libB 自己有一个 util.cpp 编译成了 util.o,同时 libA.a 中也有一个同名文件 util.o,于是,libA.a 中的util.o 最终覆盖了 libB.a 中的 util.o。虽然 libB.a build成功了,但其实是不能用的,因为 libB 自己的 util.o 的实现已经丢失了。
接下来,用一个example小例子程序去link libB.a 的时候,编译器报错说 util.o 中有函数实现没找到。用nm -c util.o 查看,其中的实现都是 libA.a 中的。
【解决】
为 libA.a 打散后的.o 文件创建一个单独的文件夹,比如 obj/libA,将 libA.a 中的.o 文件都放到 obj/libA 文件夹中,然后为生成 libB.a 做 ar 的时候,把这个文件夹下的 .o 文件也打包进去。
也可以简单地将两个同名文件中的一个的源文件换个名字,然后重新编译链接。