是否可以编译无需重新编译即可在所有Linux发行版中执行的CC ++源代码?

是否可以编译无需重新编译即可在所有Linux发行版中执行的CC ++源代码?,第1张

是否可以编译无需重新编译即可在所有Linux发行版中执行的C / C ++源代码?

不,您不能编译在所有Linux发行版中执行的可执行文件。但是,您可以编译可在人们倾向于关注的大多数发行版上运行的可执行文件。

  1. 编译32位。为您愿意支持的最低CPU级别进行编译。

  2. 构建自己的glibc版本。使用该

    --enable-kernel
    选项设置您愿意支持的最低内核版本。

  3. 编译您打算使用的所有其他库。使用glibc构建中的标头和所选的CPU /编译器标志。

  4. 静态链接

  5. 对于您无法静态链接的任何内容(例如,如果您需要访问系统的默认名称解析或需要PAM),则必须设计自己的帮助程序和API。将源发布给帮助程序进程,然后让他们(或您的安装程序)对其进行编译。

  6. 在您需要支持的所有平台上进行全面测试。

如果某些库调用的函数无法使用此机制,则可能需要对其进行调整。这包括

dlopen
gethostbyname
iconv_open
,等等。(这些功能从根本上依赖于动态链接。请参见上面的第5步。在链接这些功能时,您会得到警告。)

另外,如果您不小心,时区可能会中断,因为您的代码可能无法理解系统的区域格式或区域文件位置。(您将不会收到任何警告。它将无法正常工作。)

大多数执行此 *** 作的人使用的最低支持的CPU是Pentium 4,最低支持的内核版本是2.6.0。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5012447.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-14
下一篇 2022-11-14

发表评论

登录后才能评论

评论列表(0条)

保存