- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
构建编译器时,除了 glibc 版本之外,还必须指定 Linux 头文件版本和支持的最低内核版本。然后在目标机器上有实际的内核版本和 glibc 版本(有它自己的内核头文件版本和支持的最低内核版本)。我很困惑试图理解这些版本是如何组合在一起的。
示例 1:假设我的系统带有针对内核头文件 3.14 构建的 glibc 2.13。这有任何意义吗? glibc 2.13(2011 年发布)如何使用 3.14(2014 年发布)的新内核功能?
示例 2:假设我有一个 glibc 版本更新 2.13 的编译器。编译后的程序可以在带有 glibc 2.13 的系统上运行吗?如果编译器的 glibc 版本旧2.13?
示例 3:来自 https://sourceware.org/glibc/wiki/FAQ#What_version_of_the_Linux_kernel_headers_should_be_used.3F我知道如果旧内核满足编译 glibc 时使用的“最低内核版本”,则可以使用旧内核。但我不明白 反过来(使用旧内核头文件编译 GNU C 库并在最新内核上运行)不一定按预期工作。例如,如果您使用旧内核头文件编译 GNU C 库,则不能使用新内核功能。
。这是唯一会发生在我身上的事吗?如果内核比编译时更新,它不会破坏 glibc 中的某些东西吗?
示例 4:在 glibc 设置中做更多细微的差别(例如,将可执行文件链接到 glibc 版本 2.X,根据内核头文件 3.Y 编译,支持的最小值内核版本 2.6.A 并在具有相同 glibc 2.X 的系统中执行,但针对内核头文件 3.Z 进行编译,支持最小值内核版本 2.6.B) 有什么影响?我怀疑他们不是,但想确定一下。
这么多问题 :) 谢谢!
最佳答案
您不能轻易地(无论这个词的定义是什么)将较新的内核功能与旧版本的 glibc 一起使用。如果你真的需要,你可以直接调用系统调用(使用 syscall()
库函数)并从用户空间内核头文件(新内核中的东西)中挖掘任何必要的常量值和数据结构保存在 include/uapi
下)。另一方面,内核开发人员通常 promise 不会破坏较新内核中的遗留功能,因此较旧的 glibc 版本会继续按预期工作(好吧,差不多)。
较旧的程序仍然可以使用较新版本的 glibc,因为 glibc 支持符号的版本控制(有关详细信息,请参见此处:https://www.kernel.org/pub/software/libs/glibc/hjl/compat/)。如果您的程序在没有特殊规定的情况下与较新版本的 glibc 动态链接(如上面的链接中所述),您将无法使用较旧版本的 glibc 库运行它(动态链接器会提示未解析的符号,因为正确的符号版本将不可用)。
关于c - 各种 glibc 和 Linux 内核版本兼容性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27171485/
这个问题在这里已经有了答案: Multiple glibc libraries on a single host (11 个回答) 5年前关闭。 有没有办法在本地文件夹中安装新版本的 GLIBC?我将
这个问题在这里已经有了答案: Deploying Yesod to Heroku, can't build statically (4 个回答) 1年前关闭。 我有两台机器 RHEL 4机 RHEL
我在 C 启动时读取 article ,它指的是函数 __libc_csu_init 。谁能告诉我CSU代表什么? 最佳答案 我在 libc p 中找到了对“ C s tart u p”的引用。 这远
我正在使用 AlpineLinux(安装在我的计算机上,而不是安装在 docker 中)并且我正在尝试使用依赖于 glibc 的共享库。 由于 Glibc 没有集成到这个发行版中,我看到开发了一个替代
所以我正在玩 Alpine Linux,它使用 musl 与 glibc。 我发现由于这个选择,我无法运行 Oracle Java 或在 glibc 下构建的静态二进制文件。 musl 是否应该与更广
在构建 glibc 时,出现此错误。 *glibc/build/elf/dl-allobjs.os: file not recognized: File format not recognized c
我一直在寻找没有好的结果。 我想知道在文本中解释为 Malloc Maleficarum 或 Malloc Des-Malleficarum 的技术在 glibc 2.12.1 版本中是否有效。 在提
我在 CentOS 上安装 gcc 时遇到问题。 我的命令的输出sudo yum install gcc: Loaded plugins: fastestmirror Loading mirror s
我想下载gzip类型的mariadb,但是我发现它有很多文件可以下载,例如mariadb-10.2.6-linux-x86_64.tar.gz,mariadb-10.2.6-linux-glibc_2
我想尝试使用不同的 glibc 的 sin 函数。他们是否可以在不编译整个 glibc 的情况下使用不同 glibc 版本的 sin 函数? 我已经在我的虚拟 ubuntu 机器上下载了不同版本的 g
我要在超算中心的目录下安装一个软件,但是sudo,root,连apt-get,yum都不能用...这个软件需要glibc2.7,所以我得手动安装gcc和glibc(因为我无法更改内置 gcc 的路径来
我正在研究需要在多个不同的嵌入式平台上运行的 C 和 C++ 程序,为此我有交叉编译器,因此我可以在我的 x86 桌面上进行构建。 我在某些功能上遇到了一个可怕的问题,例如“strtod()”。这是我
我遇到了一个非常烦人的问题:我有一个程序,它在开始时创建一个线程,该线程将在执行期间启动其他内容(fork() 紧随其后的是 execve())。 这是我的程序达到(我认为)死锁时两个线程的 bt:
我刚刚发现,glibc 2.23 有一个关于 stdio 函数 fmemopen() 的错误,参见例如Using rewind() on a FILE* opened with fmemopen .
[root@localhost Keystone2]# sudo rpm -ivh glibc-2.3.4-2.9.audit.x86_64.rpm --nodeps --force warning:
从该系列中很容易找到如何使用 dlsym()和其他函数,但是在内部如何工作呢?是否可以编写自己的,容易实现的dlsym()? 我想知道是否有可能实现类似的行为,但在不将与-ldl链接的情况下实现(可以
嗨,我目前使用的是 ubuntu 9.10 和 glibc 版本 2.11.1-0,好吧,我正在做一个项目,我想用 glibc 的另一个版本(2.5-58)进行测试,我想知道以下与此相关的事情: 如何
我已经下载了glibc,这样我就可以修改它的代码然后使用它。所以只是为了玩玩它,我更改了 glibc 的 stdio-common 目录中的 printf 函数,以便它打印“你可以看到我吗?”。 in
我正在集群上的 conda 环境中部署 R 脚本。该脚本加载了一些需要 glibc 版本 >= 2.14 的包。虽然我的系统的 glibc 版本为 2.14,但集群的 glibc 版本为 2.12,我
所以。我有一个问题,我在一台机器上有两个版本的 GCC。 3.4.6 和 4.1 这是由于新软件的一些依赖性问题。 (需要 glibc 4.1) 当我将这个新软件与 4.1 库链接时,它链接得很好。但
我是一名优秀的程序员,十分优秀!