将lambda作为默认参数传递时出错



下面的代码编译得很好,直到我取消注释行: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 << "defaultn";
};
// trying a lambda that takes another lambda as parameter
auto lambda = [](auto&& f = lambdaDefaultParameter)
{
f();
};
lambda([]() {std::cout << "testn"; }); // ok
//lambda(); // error
}

您无法捕获将自动存储持续时间作为默认参数的内容。要么将lambda移动到全局范围,要么按如下方式捕获它:

#include <iostream>
#include <functional>
int main()
{   
auto lambdaDefaultParameter = []()
{
std::cout << "defaultn";
};
auto lambda = [](std::function<void()> f =
[lambdaDefaultParameter](){ lambdaDefaultParameter(); }
)
{
f();
};
lambda([]() {std::cout << "testn"; });
lambda();
}

输出:

test
default

显然auto遇到了一些问题。指定类型显式地适用于MSVC。g++仍然没有编译它,因为if认为静态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 << "defaultn";
};
// 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 << "testn"; }); // ok
lambda(); // ok
}

最新更新