问题描述
下面的代码编译得很好,直到我取消注释该行:lambda();
。为什么我不使用依赖默认参数的函数会编译,但是当我尝试使用默认参数时,它不再编译?
#include <iostream>
int main()
{
static auto lambdaDefaultParameter = []() // must be static,otherwise I get the error that a local variable can't be a default parameter
{
std::cout << "default\n";
};
// trying a lambda that takes another lambda as parameter
auto lambda = [](auto&& f = lambdaDefaultParameter)
{
f();
};
lambda([]() {std::cout << "test\n"; }); // ok
//lambda(); // error
}
解决方法
您无法捕获将自动存储持续时间作为默认参数的内容。要么将 lambda 移动到全局范围内,要么按如下方式捕获它:
#include <iostream>
#include <functional>
int main()
{
auto lambdaDefaultParameter = []()
{
std::cout << "default\n";
};
auto lambda = [](std::function<void()> f =
[lambdaDefaultParameter](){ lambdaDefaultParameter(); }
)
{
f();
};
lambda([]() {std::cout << "test\n"; });
lambda();
}
输出:
test
default
,
显然 auto
遇到了一些麻烦。明确指定类型适用于 MSVC。 g++ 仍然不编译它,因为如果认为静态 lambda 是局部变量。当我不在 lambdaDefaultParameter
中使用 static 关键字时,MSVC 只认为它是一个局部变量。
#include <iostream>
int main()
{
static auto lambdaDefaultParameter = []() // must be static,otherwise I get the error that a local variable can't be a default /parameter
{
std::cout << "default\n";
};
// trying a lambda that takes another lambda as parameter
auto lambda = [](void(*f)() = lambdaDefaultParameter) // ok
//auto lambda = [](auto f = lambdaDefaultParameter) // error
{
f();
};
lambda([]() {std::cout << "test\n"; }); // ok
lambda(); // ok
}