微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决将 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 << "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
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。