考虑以下代码
#include <iostream>
#include <functional>
namespace A {
template<typename T>
struct X {
using Function = std::function<int(T)>;
static Function f;
};
template<typename T>
typename X<T>::Function X<T>::f = [](auto) { return 42; };
}
int main() {
std::cout << A::X<int>::f(0);
}
GCC和clang都接受此代码,但MSVC(测试版本19.00.23506)给出:
error C2888: 'auto <lambda_ce48e25aa4b9e3d225584044e4eae9e2>::operator ()(_T1) const': symbol cannot be defined within namespace 'A'
实际上,如果我删除命名空间A并在全局命名空间中定义所有内容,则接受代码。如果我将lambda表达式设为非泛型,则相同。
有人可以解释MSVC在此代码中看到的问题是什么吗? C ++ Standard是否限制在上面的上下文中使用泛型lambda?
答案 0 :(得分:6)
是的,这是一个MSVC错误,但已修复VS2017 15.6预览2.0
标准中没有规范限制通用lambda只存在于全局命名空间中。
问题的POC可以在这里找到:https://godbolt.org/g/BESMK4
MSVC无法推断auto
在每种情况下都是T
,并且失败。
如果您需要将其与MSVC配合使用,请将auto
替换为显式T
:
template<typename T>
typename X<T>::Function X<T>::f = [](T) { return 42; };