gcc编译32位代码出错

在VMware上的Ubuntu环境中,使用GCC编译时遇到链接错误,找不到Scrt1.o、crti.o等文件。尝试过设置环境变量和重新安装32位包但未成功。最终通过在StackOverflow上找到解决方案,问题出在缺少32位支持文件。执行`sudo apt install gcc-multilib`命令后,成功安装了缺失的32位支持,从而能正常进行编译。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目场景:

vmware上的unbuntu终端,用gcc编译文件出错


问题描述:

前几天用vmware上的unbuntu终端,用gcc编译文件,出现了如下bug

/usr/bin/ld: cannot find Scrt1.o: No such file or directory
/usr/bin/ld: cannot find crti.o: No such file or directory
/usr/bin/ld: skipping incompatible /usr/lib/gcc/x86_64-linux-gnu/9/libgcc.a when searching for -lgcc
/usr/bin/ld: cannot find -lgcc
/usr/bin/ld: skipping incompatible /usr/lib/x86_64-linux-gnu/libgcc_s.so.1 when searching for libgcc_s.so.1
/usr/bin/ld: cannot find libgcc_s.so.1
/usr/bin/ld: skipping incompatible /usr/lib/gcc/x86_64-linux-gnu/9/libgcc.a when searching for -lgcc
/usr/bin/ld: cannot find -lgcc
collect2: error: ld returned 1 exit status

在这里插入图片描述


原因分析:

错误提示显示好几个文件都找不到,而且我之前用gcc编译文件也没有出现这个问题,-m32也用过。
我上网查了很多办法,有的说要设置环境变量,有的说要重下(我之前其实下过)32位的包(一般下载的gcc默认是64位的),但是我试过,都没有用,气得我把unbuntu卸载了之后重装,发现还是一样的提示。


解决方案:

最后在stackflow上找到了答案
https://stackoverflow.com/questions/6329887/compiling-problems-cannot-find-crt1-o(网站有时候不稳定,多试几次就OK)

只要执行这个命令,下载一个东西就可以正常编译了。

sudo apt install gcc-multilib

stackflow解释:The problem is you likely only have the gcc for your current architecture and that’s 64bit. You need the 32bit support files. For that, you need to install them

### 使用 GCC 编译 32 程序的方法 在现代操作系统中,默认情况下,GCC 编译器会生成与主机架构匹配的可执行文件。然而,有时需要显式地指示编译器生成针对不同目标平台(如 32 )的二进制文件。以下是具体的操作步骤和注意事项。 --- #### 环境准备 为了能够成功编译 32 程序,首先需要确保系统支持多架构编译功能。对于基于 Debian 或 Ubuntu 的发行版,可以通过安装 `gcc-multilib` 和 `g++-multilib` 来实现这一需求[^2]。 ```bash sudo apt install gcc-multilib g++-multilib ``` 此命令会在系统中启用 multilib 支持,允许在同一环境中同时编译 32 和 64 代码。 --- #### 编译选项设置 在实际编译过程中,需要向 GCC 提供额外的标志以指定目标架构为 32 。常用的选项包括: 1. **`-m32`** 此选项告诉编译器将 `int`, `long` 和指针大小设定为 32 长度,适合 i386 架构[^3]。 示例: ```bash gcc -m32 source.c -o output_program ``` 2. **其他相关选项** 根据具体的硬件环境,还可以考虑以下替代方案: - `-mx32`:将 `int`, `long` 和指针设为 32 ,但仍然运行在 X86-64 平台上[^3]。 - `-m64`:默认行为,用于生成 64 程序(仅作对比说明)。 注意:如果尝试在不支持 multilib 的环境下使用这些选项,可能会遇到错误提示,例如缺少必要的头文件或库文件。 --- #### 验证编译结果 完成编译后,可以利用 `file` 命令确认最终产物的实际架构属性。 ```bash file output_program ``` 预期输出应类似于以下内容,表明该程序确实是为 32 体系设计的: ``` output_program: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux.so.2, for GNU/Linux 3.2.0, not stripped ``` --- #### 特殊情况处理 某些老旧系统可能不具备内置的 multilib 支持。在这种情形下,可以选择手动配置交叉编译工具链或者借助第三方资源包来扩展能力。例如,在 CentOS 7 中,虽然官方仓库提供了基础组件,但仍需正确调整 yum 源地址才能顺利获取所需依赖项[^4]。 --- ### 总结 综上所述,通过合理运用 `-m32` 参数配合 multilib 组件即可轻松达成跨架构开发目的。不过需要注意的是,由于历史原因以及技术演进方向的不同,部分高级特性或许无法完全兼容低字节模式下的运作逻辑。 ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值