【问题标题】:Error "undefined reference to 'std::cout'"未定义对“std::cout”的引用
【发布时间】:2015-03-29 23:40:45
【问题描述】:

这就是例子吗:

#include <iostream>
using namespace std;
int main()
{
    cout << "Hola, moondo.\n";
}

它抛出错误:

gcc -c main.cpp gcc -o edit main.o  main.o: In function `main':
main.cpp:(.text+0xa): undefined reference to `std::cout'
main.cpp:(.text+0xf): undefined reference to `std::basic_ostream<char,std::char_traits<char> >& std::operator<< <std::char_traits<char>>(std::basic_ostream<char, std::char_traits<char> >&, char const*)'
main.o: In function `__static_initialization_and_destruction_0(int,int)':
main.cpp:(.text+0x3d): undefined reference to `std::ios_base::Init::Init()'
main.cpp:(.text+0x4c): undefined reference to `std::ios_base::Init::~Init()' collect2: error: ld
returned 1 exit status make: *** [qs] Error 1

另外,这个例子:

#include <iostream>
int main()
{
    std::cout<<"Hola, moondo.\n";
}

抛出错误:

gcc -c main.cpp gcc -o edit main.o  main.o: In function `main':
main.cpp:(.text+0xa): undefined reference to `std::cout'
main.cpp:(.text+0xf): undefined reference to `std::basic_ostream<char,std::char_traits<char> >& std::operator<<<std::char_traits<char>>(std::basic_ostream<char,std::char_traits<char> >&, char const*)'
main.o: In function `__static_initialization_and_destruction_0(int,int)': main.cpp:(.text+0x3d): undefined reference to `std::ios_base::Init::Init()'
main.cpp:(.text+0x4c): undefined reference to `std::ios_base::Init::~Init()' collect2: error: ld
returned 1 exit status make: *** [qs] Error 1

注意:我使用的是 Debian Wheezy。

【问题讨论】:

  • 尝试g++ 而不是gccgcc 用于 C,不会让您访问 C++ 标准库。
  • 嗯,这绝对解决了问题。据我了解,GCC 是 Gnu Compiler Collection 的首字母缩写词。它不应该在需要时调用 g++ 编译器吗?所以命令 gcc 改为调用 c 编译器...
  • @D1X 这是因为您将链接器与编译器分开调用。当您编写 gcc -o edit main.o 时,它并不知道 main.o 将需要 C++ 启动库。
  • 问:在需要的时候不应该调用g++编译器吗? A:不超过 gcc 应该根据需要调用 gfortran、gjc、...等。

标签: c++ c++11 gcc cout


【解决方案1】:

编译程序:

g++ -Wall -Wextra -Werror -c main.cpp -o main.o
     ^^^^^^^^^^^^^^^^^^^^ <- For listing all warnings when your code is compiled.

因为cout 存在于C++ 标准库中,当使用gcc 时需要与-lstdc++ 进行显式链接g++默认链接标准库。

使用gcc,(g++ 应优先于gcc

gcc main.cpp -lstdc++ -o main.o

【讨论】:

  • 可以用来编译C++代码,问题是它没有link与C++库。 gcc 将工作得很好,如果你只是添加 -lstdc++
  • 在给出 gcc/g++ 命令行示例时,请始终包含-Wall - 它有助于在早期阶段让新手养成良好习惯,并为每个人节省更多时间。 ;-)
  • 从什么时候开始 iostreams 和 std::cout 成为标准模板库的一部分?
  • 为什么需要-Werror?我已经修改了文档,如果我理解得很好,将会产生警告错误,并使我的项目更不容易编译。
  • @D1X:因为程序员中有一种忽略警告的坏习惯。实际上,-Wall 甚至-Wextra 警告的所有问题要么是一个非常现实的问题,要么是可以很容易修复的草率编码。这里的信息是养成一种习惯,你认为编译器警告是一个有用的指针,指向你的代码可以改进的地方,而不是讨厌。如果 OP 使用了-Wall -Wextra,那么这里有 数百 个关于 SO 的问题,这些问题一开始就没有必要。 -Werror 只是在强化这一点。
【解决方案2】:

是的,使用g++ 命令对我有用:

g++ my_source_code.cpp

【讨论】:

  • 然后使用./a.out运行
  • 经典。我总是忘记g++ 是一个东西。
【解决方案3】:

假设code.cpp是源代码,下面不会抛出错误:

make code
./code

这里第一个命令编译代码并创建一个同名的可执行文件,第二个命令运行它。这种情况下不需要指定g++关键字。

【讨论】:

  • 一个不错的替代方案,也是实用的快速介绍。
【解决方案4】:

生成文件

如果您正在使用 makefile 并且最终像我一样来到这里,那么这可能就是您正在寻找的内容,或者:

如果您使用的是makefile,则需要更改cc,如下所示

my_executable : main.o
    cc -o my_executable main.o

CC = g++

my_executable : main.o
    $(CC) -o my_executable main.o

【讨论】:

    【解决方案5】:

    FWIW,如果您想要一个 makefile,您可以通过以下方式回答 在顶部切换编译器。

    # links stdc++ library by default
    # CC := g++
    # or
    CC := cc
    
    all: hello
    
    util.o: util.cc
            $(CC) -c -o util.o  util.cc
    
    main.o: main.cc
            $(CC) -c -o main.o  main.cc
    
    # notice -lstd++ is after the .o files
    hello: main.o util.o
            $(CC) -o hello main.o util.o -lstdc++
    
    clean:
            -rm util.o main.o hello
    

    【讨论】: