为什么静态 (.a) 库依赖于非静态编译的共享对象(例如 libopenssl)?
您可以构建的每个静态库都会有未解析的符号,例如
int my_open_for_read(const char *filename)
{
return open(filename, O_RDONLY); // unresolved reference to open
}
正如 Marc Glisse 指出的,这是一个普通的未解析符号,不是依赖于 libc.so。
- 我该如何解决这个问题?
这里没有要解决的问题。链接二进制文件时,您可以决定哪些库要静态链接,哪些要动态链接。
尝试手动添加 -lssl 似乎不起作用。
这应该可行:
gcc main.o -lthis -lssl
可能你做了类似的事情
gcc main.o -lssl -lthis
这是错误的:链接行matters上的库顺序。
如何让二进制文件编译并且没有外部依赖?
大多数操作系统都支持使用完全静态的二进制文件。一般来说,这不应该是您的目标:它使 less 可移植二进制文件,强烈建议不要使用它们。
如果您确实想生成完全静态的二进制文件,请将其与-static 标志链接。
你为什么说全静态不那么便携?
因为they are。
如果用户没有完全相同的库版本,则二进制文件将不能与共享库一起移植,但可以与静态库一起移植。
这是不正确的:大多数共享库都支持向后兼容性,例如libc.so.6 2.22 版将愉快地运行与 10 年前的 2.3.6 版链接的可执行文件。
如果你使用 ldd firefox
你需要注意你在做什么:
file -L `which /usr/bin/firefox`
/usr/bin/firefox: POSIX shell script, ASCII text executable
如果您查看 shell 脚本,您会发现它调用了/usr/lib/firefox/firefox,并且该二进制文件是动态链接的:
ldd /usr/lib/firefox/firefox
linux-vdso.so.1 => (0x00007ffca278d000)
libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f511731b000)
libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f5117117000)
libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f5116e13000)
libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f5116b0d000)
libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f51168f7000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f5116532000)
/lib64/ld-linux-x86-64.so.2 (0x00007f5117757000)