linux 内存不足 编译,在Linux上的C源文件上运行’gcc’会出现“cc1plus:内存不足分配…”错误消息...

在Ubuntu上使用’gcc‘编译C源文件时遇到了一个令人费解的问题.解决了这个问题后,我想在这里发布它,以免其他人解决问题.

为了这个报告,我们有最简单的C“Hello,World”程序,存储在main.cpp中:

#include

int main (int argc, char *argv[])

{

return 0;

}

当我运行命令时:

gcc main.cpp

我收到错误消息:

cc1plus: out of memory allocating 1677721600 bytes after a total of 475136 bytes

我确认我正在编译正确的位数(即32位).我做错了什么?

解决方法:

事实证明,我已将C源文件保存为UTF-16 Unicode编码文件,并在文件开头添加了前导Unicode字节顺序标记(BOM)字节.该文件在Windows系统上保存为UTF-16,提交给版本控制系统,然后签出到Linux. gcc支持Unicode编码为UTF-8,但不支持Unicode编码为UTF-16.

解决方案是将源文件转换回标准的非Unicode编码.

标签:c,linux,gcc

来源: https://codeday.me/bug/20190926/1820131.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值