您可以在类的初始化列表中使用 lambda 吗?

Can You Use a Lambda In A Class' Initialization List?

本文关键字:lambda 列表 初始化      更新时间:2023-10-16

我正在尝试使用 C++11 Lambda 来初始化类的 const 成员变量。

一个简单得多的例子:

class Foo
{
public:
    const int n_;
    Foo();
};
Foo::Foo()
:   n_( []() -> int { return 42; } )
{
}
int main()
{
    Foo f;
}

在 MSVC10 中,这将产生:

error C2440: 'initializing' : cannot convert from '`anonymous-namespace'::<lambda0>' to 'const int'

在 IDEONE 中,这会产生:

prog.cpp: In constructor 'Foo::Foo()':
prog.cpp:9:34: error: invalid conversion from 'int (*)()' to 'int'

开始明白我不能在类的初始化列表中使用 lambda。

我可以吗? 如果是这样,正确的语法是什么?

您正在尝试从lambda转换为int - 您应该改为调用lambda:

Foo::Foo()
:   n_( []() -> int { return 42; }() ) //note the () to call the lambda!
{
}

您的变量声明为 int

是否要调用 lambda?这应该有效:

n_(([]() -> int { return 42; })())

还是您想要一个类型 std::function<> 的变量?

您正在创建一个 lambda,正如编译器所述,您正在尝试将 lambda 本身存储在n_中。