在 Clang++ 中定位 iostream:致命错误:找不到“iostream”文件

ste*_*esu 10 c++ linux clang clang++

我编写了以下简单的 C++ 程序:

#include <iostream>

using namespace std;

int main() {
    cout << "Hello, World" << endl;
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

当我用 g++ 编译它时,它工作得很好。当我尝试使用 Clang++ 进行编译时,出现以下错误:

main.cpp:1:10: fatal error: 'iostream' file not found
#include <iostream>
         ^~~~~~~~~~
1 error generated.
Run Code Online (Sandbox Code Playgroud)

使用-v参数运行,我看到以下内容:

ignoring nonexistent directory "/usr/bin/../lib/gcc/x86_64-linux-gnu/8/../../../../include/c++/x86_64-linux-gnu"
ignoring nonexistent directory "/usr/bin/../lib/gcc/x86_64-linux-gnu/8/../../../../include/c++/backward"
ignoring nonexistent directory "/include"
ignoring duplicate directory "/usr/include/clang/6.0.0/include"
#include "..." search starts here:
#include <...> search starts here:
 /usr/bin/../lib/gcc/x86_64-linux-gnu/8/../../../../include/c++
 /usr/include/clang/6.0.0/include
 /usr/local/include
 /usr/include/x86_64-linux-gnu
 /usr/include
End of search list.
Run Code Online (Sandbox Code Playgroud)

分别查看这些文件夹,我发现在/usr/bin/../lib/gcc/x86_64-linux-gnu/8/../../../../include/c++(或更简洁地说,在/usr/include/c++)中我有以下目录:

drwxr-xr-x   5 root root 4.0K Feb  4 09:38 .
drwxr-xr-x 101 root root  20K Feb  4 12:22 ..
drwxr-xr-x  12 root root  12K May 24  2018 5
drwxr-xr-x  12 root root  12K Oct  9 14:53 7
drwxr-xr-x   5 root root 4.0K Feb  4 09:38 v1
lrwxrwxrwx   1 root root    1 Apr 11  2018 5.5.0 -> 5
lrwxrwxrwx   1 root root    1 Apr 15  2018 7.3.0 -> 7
Run Code Online (Sandbox Code Playgroud)

在、 和目录中的每一个中5,都存在一个名为7v1iostream

此外,在/usr/include/x86_64-linux-gnu存在一个c++目录,其长相酷似这一个(有575.5.0,和7.3.0目录)。

/usr/include存在一个c++与上面两个完全一样的目录

我不确定我的开发环境是如何变得如此混乱,但此时我只想知道如何修复它,以便 Clang++ 成功找到这 9 个实例之一,iostream而不是抛出它没有的错误存在。我是否需要添加一个环境变量来告诉 Clang 在哪里查看?我是否需要传递命令行参数来告诉 Clang 递归搜索?

更新 (1)

当我尝试使用构建时,libc++出现以下错误:

$> clang++ -stdlib=libc++ main.cpp
/usr/bin/ld: cannot find -lc++abi
clang: error: linker command failed with exit code 1 (use -v to see invocation)
Run Code Online (Sandbox Code Playgroud)

当我尝试使用手动覆盖的包含路径进行构建时,出现以下错误:

$> clang++ -isystem /usr/include/c++/7 -isystem /usr/include/x86_64-linux-gnu/c++/7 main.cpp
/usr/bin/ld: cannot find -lstdc++
clang: error: linker command failed with exit code 1 (use -v to see invocation)
Run Code Online (Sandbox Code Playgroud)

当我同时尝试这两种方法时,出现以下(非常大的)错误:

$> clang++ -isystem /usr/include/c++/7 -isystem /usr/include/x86_64-linux-gnu/c++/7 -stdlib=libc++ main.cpp
In file included from main.cpp:1:
In file included from /usr/include/c++/7/iostream:39:
In file included from /usr/include/c++/7/ostream:38:
In file included from /usr/include/c++/7/ios:42:
In file included from /usr/include/c++/7/bits/ios_base.h:41:
In file included from /usr/include/c++/7/bits/locale_classes.h:40:
In file included from /usr/include/c++/7/string:52:
In file included from /usr/include/c++/7/bits/basic_string.h:6352:
In file included from /usr/include/c++/7/ext/string_conversions.h:41:
In file included from /usr/include/c++/7/cstdlib:77:
/usr/include/c++/7/bits/std_abs.h:56:3: error: declaration conflicts with target of using declaration already in scope
  abs(long __i) { return __builtin_labs(__i); }
  ^
/usr/include/c++/v1/stdlib.h:111:44: note: target of using declaration
inline _LIBCPP_INLINE_VISIBILITY long      abs(     long __x) _NOEXCEPT {return  labs(__x);}
                                           ^
/usr/include/c++/7/bits/std_abs.h:52:11: note: using declaration
  using ::abs;
          ^
/usr/include/c++/7/bits/std_abs.h:61:3: error: declaration conflicts with target of using declaration already in scope
  abs(long long __x) { return __builtin_llabs (__x); }
  ^
/usr/include/c++/v1/stdlib.h:113:44: note: target of using declaration
inline _LIBCPP_INLINE_VISIBILITY long long abs(long long __x) _NOEXCEPT {return llabs(__x);}
                                           ^
/usr/include/c++/7/bits/std_abs.h:52:11: note: using declaration
  using ::abs;
          ^
In file included from main.cpp:1:
In file included from /usr/include/c++/7/iostream:39:
In file included from /usr/include/c++/7/ostream:38:
In file included from /usr/include/c++/7/ios:42:
In file included from /usr/include/c++/7/bits/ios_base.h:41:
In file included from /usr/include/c++/7/bits/locale_classes.h:40:
In file included from /usr/include/c++/7/string:52:
In file included from /usr/include/c++/7/bits/basic_string.h:6352:
In file included from /usr/include/c++/7/ext/string_conversions.h:41:
/usr/include/c++/7/cstdlib:177:3: error: declaration conflicts with target of using declaration already in scope
  div(long __i, long __j) { return ldiv(__i, __j); }
  ^
/usr/include/c++/v1/stdlib.h:116:42: note: target of using declaration
inline _LIBCPP_INLINE_VISIBILITY  ldiv_t div(     long __x,      long __y) _NOEXCEPT {return  ldiv(__x, __y);}
                                         ^
/usr/include/c++/7/cstdlib:145:11: note: using declaration
  using ::div;
          ^
Run Code Online (Sandbox Code Playgroud)

提醒一下,我实际上只是在尝试编译 Hello, World

我还尝试使用以下命令卸载并重新安装 Clang:

$> sudo apt-get purge --auto-remove clang
$> sudo apt-get update
$> sudo apt-get install clang
Run Code Online (Sandbox Code Playgroud)

这没有效果。我正在运行 Ubuntu 18.04,但我不知道出了什么问题,也不知道从哪里开始修复它。我的构建环境一团糟。

如果可能的话,我想让 Clang 工作而不是回退到使用 G++,因为我的 IDE 似乎会自动检测 Clang 并使用它进行语法检查。这意味着我编写的每个 C++ 程序在第一行都有一个致命错误(“iostream 未找到”)并且文件的其余部分未被检查,因为第一个是致命错误。

更新 (2)

我尝试从 Ubuntu apt 存储库安装更多软件包,但没有成功:

$> sudo apt-get install libc++1 libc++1-9 libc++abi1 libc++abi1-9 llvm-9 llvm-9-dev
$> clang++ -isystem /usr/include/c++/7 -isystem /usr/include/x86_64-linux-gnu/c++/7 -stdlib=libc++ main.cpp
/usr/bin/ld: cannot find -lc++
clang: error: linker command failed with exit code 1 (use -v to see invocation)
Run Code Online (Sandbox Code Playgroud)

我也试图sudo apt-get install lc++1发现这是一个完全不相关的包。

更新 (3)

我花了几个小时试图解决这个问题,从 apt 和源代码安装多个包,尝试各种工具的不同版本,从其他来源手动复制库,甚至跳上 Clang IRC 并直接与几位知识渊博的开发人员交谈.

没有人能够弄清楚我的笔记本电脑出了什么问题,而我所做的一切都没有让它工作。

不幸的是,再过两周我就不会再有这台笔记本电脑了,所以我可能需要关闭这个问题,因为“无法重现”——因为一旦笔记本电脑不见了,我将无法复制损坏的开发环境。

was*_*mup 18

首先找到您的版本(路径):

ls /usr/include/c++/
Run Code Online (Sandbox Code Playgroud)

输出(您的版本可能有所不同):

11
Run Code Online (Sandbox Code Playgroud)

然后添加包含路径,并替换11为您的版本,例如:

-I/usr/include/c++/11 
-I/usr/include/x86_64-linux-gnu/c++/11
Run Code Online (Sandbox Code Playgroud)

建造

这在 Linux 上适用于我(并替换11为您的版本):

ls /usr/include/c++/
Run Code Online (Sandbox Code Playgroud)

通过这个简单的例子 ( main.cpp):

11
Run Code Online (Sandbox Code Playgroud)

另外,您可以使用 CPLUS_INCLUDE_PATH (并替换11为您的版本):

export CPLUS_INCLUDE_PATH=/usr/include/c++/11:/usr/include/x86_64-linux-gnu/c++/11
Run Code Online (Sandbox Code Playgroud)

然后这有效:

clang++ main.cpp -o main
Run Code Online (Sandbox Code Playgroud)

跑步:

./main
Run Code Online (Sandbox Code Playgroud)

并参见:
https://superuser.com/questions/358255/bash-environment-variable-to-include-path-of-c-libraries

如何查询clang++的默认包含路径?

Clang 看不到基本标题

https://askubuntu.com/questions/516801/clang-fails-to-compile-simple-hello-world-c-program

我希望这可以帮助别人。


Arj*_*ijk 11

该问题通常是由于clang++需要g++. 它通过查找 来检查要使用的版本gcc。如果您的系统上有更高版本的gcc没有相应的g++,它将找不到g++标头。

换句话说,在以下情况下clang++给出错误fatal error: 'iostream' file not found

  • 你只安装gcc-xx而不安装g++-xx
  • 你升级了gcc-xx却忘记升级g++-xx

因此,如果您收到错误,应该通过安装两者的最新版本来修复它,例如:

sudo apt update
sudo apt install gcc-10 g++-10 
Run Code Online (Sandbox Code Playgroud)


小智 8

我也被这个问题困扰很久了,你应该尝试删除文件夹(cd /usr/lib/gcc/aarch64-linux-gnu/8)。clang++ 不能工作的原因是这个文件夹不包含 libstdc++.a。

clang version 6.0.0-1ubuntu2 (tags/RELEASE_600/final)
Target: aarch64-unknown-linux-gnu
Thread model: posix
InstalledDir: /usr/bin
Found candidate GCC installation: /usr/bin/../lib/gcc/aarch64-linux-gnu/5
Found candidate GCC installation: /usr/bin/../lib/gcc/aarch64-linux-gnu/5.5.0
Found candidate GCC installation: /usr/bin/../lib/gcc/aarch64-linux-gnu/6
Found candidate GCC installation: /usr/bin/../lib/gcc/aarch64-linux-gnu/6.5.0
Found candidate GCC installation: /usr/bin/../lib/gcc/aarch64-linux-gnu/7
Found candidate GCC installation: /usr/bin/../lib/gcc/aarch64-linux-gnu/7.3.0
Found candidate GCC installation: /usr/lib/gcc/aarch64-linux-gnu/5
Found candidate GCC installation: /usr/lib/gcc/aarch64-linux-gnu/5.5.0
Found candidate GCC installation: /usr/lib/gcc/aarch64-linux-gnu/6
Found candidate GCC installation: /usr/lib/gcc/aarch64-linux-gnu/6.5.0
Found candidate GCC installation: /usr/lib/gcc/aarch64-linux-gnu/7
Found candidate GCC installation: /usr/lib/gcc/aarch64-linux-gnu/7.3.0
Selected GCC installation: /usr/bin/../lib/gcc/aarch64-linux-gnu/7.3.0
Run Code Online (Sandbox Code Playgroud)

检查/usr/lib/gcc/aarch64-linux-gnu/clang++中的所有文件夹会选择最后一个,确保最后一个中有libstdc++.a

  • 就是这个。我想补充一点,我发现的最简单的补救措施是安装 clang 尝试使用的 g++ 版本。因此,例如,由于在您的示例中 clang“选择”gcc 7,我知道的最简单的修复是“sudo apt install g++-7”(如果在 ubuntu 或 debian 上) (2认同)

小智 5

我发现 clang 正在使用/usr/lib/gcc/x86_64-linux-gnu/8(using clang++ -v) 中的安装,实际上这不包含文件libstdc++.a. 我没有按照另一个答案的建议删除整个目录,而是能够安装libstdc++-8-dev.

我在 Ubuntu 18.04 上;gcc 已经安装。