跑步' gcc'在Linux上的C ++源文件中给出了" cc1plus:内存不足分配..."错误信息

时间:2014-12-21 09:51:30

标签: c++ linux gcc

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

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

#include <stdio.h>

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位)。我做错了什么?

2 个答案:

答案 0 :(得分:10)

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

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

答案 1 :(得分:1)

在用C++编译MAKEFILE程序时,我遇到了同样的问题。

我找到了解决此问题的简便方法,它是从上一次编译中删除现有的二进制文件

我无法确定问题的根源,但这对我有用。