我写了下面这个简单的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
在每个5
、7
和v1
目录中,都存在一个名为iostream
的文件
同样在/usr/include/x86_64-linux-gnu
中,存在一个c++
目录,与此目录完全相同(包含5
、7
、5.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)
当我尝试用手动覆盖的include路径进行构建时,我得到了以下错误:
$> 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;
^
提醒一下我只是在编译Hello,World
我还尝试使用以下命令卸载并重新安装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和source安装了多个软件包,尝试了各种工具的不同版本,从其他源手动复制到库中,甚至跳到Clang IRC上直接与几个非常有知识的开发人员交谈。
没人能找出我的笔记本电脑出了什么问题,我也没能让它工作。
不幸的是,两周后我就没有这台笔记本电脑了,所以我可能需要将这个问题作为“无法重现”来关闭-因为一旦笔记本电脑没有了,我就没有办法复制这个坏掉的开发环境。
6条答案
按热度按时间57hvy0tb1#
我也被这个问题困扰了很久,你应该试着删除文件夹(cd /usr/lib/gcc/aarch 64-linux-gnu/8),clang不能用的原因是这个文件夹里没有libstdc. a。
检查/usr/lib/gcc/aarch 64中的所有文件夹-linux-gnu/ clang++将选择最后一个文件夹,确保最后一个文件夹中有libstdc ++. a
lfapxunr2#
我发现clang使用的是
/usr/lib/gcc/x86_64-linux-gnu/8
中的安装(使用clang++ -v
),实际上它不包含libstdc++.a
文件,而不是像另一个答案建议的那样删除整个目录,我能够只安装libstdc++-8-dev
。我用的是Ubuntu 18.04gcc已经安装。
5ktev3wc3#
首先找到您的版本(路径):
输出(您的版本可能有所不同):
然后添加包含路径,并将
11
替换为您的版本,例如:构建
这对我在Linux上是有效的(用你的版本替换
11
):下面是一个简单的例子(
main.cpp
):此外,您可以使用CPLUS_INCLUDE_PATH(并将
11
替换为您的版本):那么这个方法是可行的:
运行:
并看到:
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
希望这能帮到什么人。
bmp9r5qi4#
这个问题通常是由于
clang++
需要g++
提供的头文件而引起的。它通过查找gcc
来检查要使用的版本。如果您的系统上有更新版本的gcc
,但没有相应的g++
,它将找不到g++
头文件。换句话说,
clang++
在以下情况下给出误差fatal error: 'iostream' file not found
:gcc-xx
而不安装g++-xx
gcc-xx
,但忘记升级g++-xx
。因此,如果您遇到错误,应该通过安装这两个软件的最新版本来修复,类似于:
67up9zun5#
简短版本:请确保您的系统上有与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正在查找的位置,并注意到以下输出:
hwamh0ep6#
复制文件时未发现标题错误
我修复了将libstdc ++. a、libstdc ++ fs. a和libstdc . so从文件夹11复制到12时出现的相同错误。
我在/usr/lib/gcc/x86_64-linux-gnu/中有11和12个文件夹,在11个文件夹中有libstdc文件,但在12中没有。我用下面的命令将文件从11复制到12:
同时将此位置添加到您的路径中。.bashrc示例:
所有的错误都消失了,我可以编译没有错误,Visual Studio代码也可以看到标题。
希望这能帮到什么人。