在探索 C++ 二进制文件时,我发现libstdc++.so.6
dyn 链接到libm.so.6
和libc.so.6
:
$ ldd /lib/x86_64-linux-gnu/libstdc++.so.6
linux-vdso.so.1 (0x00007ffcb737b000)
libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fd3b2295000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fd3b1c00000)
/lib64/ld-linux-x86-64.so.2 (0x00007fd3b2396000)
libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fd3b2275000)
我的问题是:
6
名字里的意思是什么?本来以为是glibc的版本,结果版本是2.35
,与6
.$ strings /lib/x86_64-linux-gnu/libc.so.6 | grep GLIBC_2.3 GLIBC_2.3 ... GLIBC_2.35
这个后缀为何
6
如此受欢迎?libc.so.7
有什么时候发布的时间表吗?
答案1
使用 6 后缀是出于历史原因,详细信息请参见man libc
在 Linux 上。本质上,Linux 上使用了 GNU C 库的一个分支;此次发布了主要版本 2 到 5。版本 5 使用 ELF 并以共享库 soname 发布libc.so.5
。当 GNU C 库的版本 2 在 Linux 上发布时,它使用共享库 sonamelibc.so.6
以避免与早期库混淆。
相关库使用相同的后缀。有些架构使用稍微不同的后缀;例如,Alpha 和 Itanium 上的 GNU C 库是libc.so.6.1
.
GNU C 库具有强大的向后兼容性历史,并使用许多不同的机制来支持引入重大更改,而不会破坏旧的二进制文件(包括版本化符号)。仅当绝对需要无法缓解的重大更改时才会使用新的 soname ( libc.so.7
),因此我们不太可能很快看到这样的更改。
答案2
这是 ABI(应用程序二进制接口) 版本。
它仅在进行重大更改时才会增加,现在强烈避免这样做libc
,因此大多数发行版已经运行了libc.so.6
一段时间。
一般来说,它允许系统上同时存在一个库的多个不兼容版本,支持为不同版本构建的不同应用程序。
例如,Ubuntu 18.04 提供了libcurl.so.3
(通过 package libcurl3
)和libcurl.so.4
(通过 package libcurl4
),两者都是从 cURL 版本 7.58.0 构建的。