折叠表达式和函数名称查找

fold expression and function name lookup

本文关键字:查找 函数 表达式 折叠      更新时间:2023-10-16

我正在学习 C++17 中的折叠表达式。我有以下代码

#include <iostream>
#include <vector>
namespace io {
template<typename T>
std::istream &operator>>(std::istream &in, std::vector<T> &vec) {
for (auto &x : vec)
in >> x;
return in;
}
template<class... Args> void scan(Args &... args) {
(std::cin >> ... >> args);
}
}// namespace io
int main() {
std::vector<int> s(1), t(1);
io::scan(s, t);
std::cout << s[0] << ' ' << t[0] << 'n';
}

使用GCC 9.3.0,代码可以正确编译和运行,但使用 Clang 10.0.0,相同的代码无法编译:

<source>:13:16: error: call to function 'operator>>' that is neither visible in the template definition nor found by argument-dependent lookup
(std::cin >> ... >> args);
^
<source>:19:9: note: in instantiation of function template specialization 'io::scan<std::vector<int, std::allocator<int> >, std::vector<int, std::allocator<int> > >' requested here
io::scan(s, t);
^
<source>:6:15: note: 'operator>>' should be declared prior to the call site
std::istream &operator>>(std::istream &in, std::vector<T> &vec) {
^
1 error generated.

为什么 clang 重新喷射代码,而 gcc 接受它?

这是一个Clang错误。Clang 版本 11 及更早版本未正确实现折叠表达式中运算符的两阶段名称查找,并且会错误地从恰好执行折叠表达式实例化的词法范围执行第一阶段查找,而不是从模板定义的上下文执行第一阶段查找。

我最近才修复此问题(不幸的是没有赶上即将发布的 Clang 11 版本(,并且测试用例现在被 Clang 主干接受。