在Linux上的C++源文件上运行'gcc'会出现"cc1plus:内存不足分配..."错误消息

Mos*_*bin 11 c++ linux gcc

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

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

#include <stdio.h>

int main (int argc, char *argv[])
{
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

当我运行命令时:

gcc main.cpp
Run Code Online (Sandbox Code Playgroud)

我收到错误消息:

cc1plus: out of memory allocating 1677721600 bytes after a total of 475136 bytes
Run Code Online (Sandbox Code Playgroud)

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

Mos*_*bin 11

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

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

  • 我会将此报告为一个错误(假设它仍然在最近的系统上执行此操作).[我还会调查一个编辑器,比如xemacs(或者如果你更喜欢终端模式的emacs)或eclipse到你的Ubuntu机器上!] (4认同)