在gcc中使用静态和动态链接库

时间:2009-05-01 00:56:13

标签: gcc linker

我需要分发一个可以在尽可能多的x86 Linux发行版上运行的二进制文件。这意味着我必须静态链接一些库,如glibc,因为用户可能没有我使用的版本。其他库必须动态链接,如fontconfig,因为它依赖于缓存文件格式和每个系统上可能不同的硬编码位置。

执行此操作的命令行选项有哪些?如果我指定-static,那么gcc将拒绝动态链接任何库。

3 个答案:

答案 0 :(得分:79)

在现代UNIX或Linux系统上静态链接任何系统库,特别是针对libc,使得二进制文件显着 less 可移植。只是不要这样做。

相反,使用向后兼容性(在旧系统上链接的二进制文件继续在所有较新的系统上运行)对您有利,可以通过在旧系统上链接二进制文件(我使用RedHat 6.2,而我还没有看到Linux系统)我的二进制文件在过去8年中不会运行的地方),或使用类似autopackage的东西(在写完这个答案后已删除)。

回答你原来的问题:

gcc main.o -Wl,-Bstatic -lfoo -Wl,-Bdynamic

将导致链接器使用libfoo的归档版本。 [正确地使尾随-Wl,-Bdynamic非常重要,因此不要强制使用静态libc。]

答案 1 :(得分:5)

应该注意的是,在Linux下,如果没有动态库依赖它,则只能(安全地)静态链接库。这意味着如果您正在使用任何动态库,则可以忘记静态链接libc。只需使用相当旧的版本来构建libc的情况;多年来,libc一直保持着强大的ABI向后兼容性。

答案 2 :(得分:3)

尝试在链接器命令行(即.a或.so库)上删除链接到的库文件的路径,然后删除-static。这应该可以解决问题。