Locating iostream in Clang++: fatal error: 'iostream' file not found

Locating iostream in Clang++: fatal error: 'iostream' file not found

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

#include <iostream>

using namespace std;

int main() {
    cout << "Hello, World" << endl;
    return 0;
}

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

main.cpp:1:10: fatal error: 'iostream' file not found
#include <iostream>
         ^~~~~~~~~~
1 error generated.

运行 -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.

分别查看这些文件夹,我发现在 /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

在每个 57v1 目录中,存在一个名为 iostream

的文件

/usr/include/x86_64-linux-gnu 中还有一个 c++ 目录,它看起来与这个目录完全相同(575.5.07.3.0 目录)。

/usr/include 中还有一个 c++ 目录,它看起来与上面两个完全一样

我不确定我的开发环境是如何变得如此混乱的,但此时我只想知道如何修复它,以便 Clang++ 能够成功找到 iostream 的这 9 个实例之一而不是抛出它不存在的错误。我是否需要添加一个环境变量来告诉 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)

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

$> 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)

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

$> 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;
          ^

提醒一下,我真的只是想编译你好,世界

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

$> sudo apt-get purge --auto-remove clang
$> sudo apt-get update
$> sudo apt-get install clang

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

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

更新 (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)

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

更新 (3)

我又花了几个小时试图解决这个问题,从 apt 和源代码安装多个包,尝试各种工具的不同版本,从其他源手动复制到库中,甚至跳到 Clang IRC 上与几个非常有知识的开发人员直接。

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

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

我也被这个问题困扰了很久time.You应该试试删除文件夹(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

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

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

ls /usr/include/c++/

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

9

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

-I/usr/include/c++/9 
-I/usr/include/x86_64-linux-gnu/c++/9

建造

这适用于我 Linux:

clang++ -I/usr/include/c++/9 -I/usr/include/x86_64-linux-gnu/c++/9 -L /usr/lib/gcc/x86_64-linux-gnu/8 main.cpp -o main

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

#include <iostream>
int main() { std::cout << "Hi\n"; }

此外,您还可以使用 CPLUS_INCLUDE_PATH:

export CPLUS_INCLUDE_PATH=/usr/include/c++/9:/usr/include/x86_64-linux-gnu/c++/9

然后这个有效:

clang++ main.cpp -o main

运行:

./main

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

How to query the default include paths of clang++?

Clang doesn't see basic headers

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

我希望这对某人有所帮助。

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

我在 Ubuntu 18.04; gcc 已经安装。

简短版本:确保您的系统上有与最新版本的 gcc 相对应的 libstdc++。

我的系统上一切正常,直到有一天我尝试用 clang 编译,但由于找不到 iostream 而崩溃。但是 g++ 编译得很好。

我在Ubuntu系统上遇到这种情况是因为我安装了较新版本的gcc,但没有安装相应的c++东西。在我的特殊情况下,我安装了 gcc-10 但没有安装 libstdc++-10。当 clang 运行 时,它将 gcc-10 识别为最新版本的 gcc(它也识别了其他版本,但忽略了它们),并且只在适当的位置查找 gcc-10。

为了解决 clang 找不到 iostream 的问题,我安装了 libstdc++-10 以对应 clang 已经查找的位置。我通过向失败的编译命令添加“-v”来确定 clang 正在查找的位置,并注意到此输出:

ignoring nonexistent directory "/usr/bin/../lib/gcc/x86_64-linux-gnu/10/../../../../include/c++/x86_64-linux-gnu"
ignoring nonexistent directory "/usr/bin/../lib/gcc/x86_64-linux-gnu/10/../../../../include/c++/backward"

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

换句话说,clang++ 给出错误 fatal error: 'iostream' file not found when:

  • 你只安装了 gcc-xx 而没有安装 g++-xx
  • 您升级 gcc-xx 但忘记升级 g++-xx

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

sudo apt update
sudo apt install gcc-10 g++-10