在Linux上的C ++源文件上运行“gcc”会导致“cc1plus:内存不足……”错误消息

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

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

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