为什么lambda表达式可以返回本地枚举类类型?

cws*_*idt 7 lambda scope type-safety enum-class c++14

为什么以及如何运作?什么类型的'自动'在这里?

auto lambda = [](){
    enum class Local { X=0 };
    return Local::X;
};

auto x = lambda(); // No error! Why and what type is auto in this case?
auto y = Local::X; // Error! Of course!
Run Code Online (Sandbox Code Playgroud)

enum class Local不拉姆达类型以外公知的.它是一个enum class,因此不能没有int演员阵容,AFAIK.如何返回本地类型auto以及它在lambda之外的类型是什么?

yur*_*hek 5

这与lambdas或enum classes 无关,这适用于任何具有推导返回类型的函数中的任何本地类型:

auto f() {
    struct X {};
    return X{};
}

int main() {
    auto x = f();
}
Run Code Online (Sandbox Code Playgroud)

类型x不能直接从外部函数范围引用,但确实在其中X定义f.


wal*_*lly 4

为什么以及如何运作?

它之所以有效,是因为:

  • lambda 表达式会导致在编译时生成并命名 唯一的类。
    • 该类的类型由编译器内部命名。
    • 因此编译器可能会想出类似<lambda_30560bd1c97ca682d011cd006c362574>::()::Localfor 的东西x

enum class您可以获取 lambda 的类型,然后使用它来声明其中包含的类型的对象:

auto lambda = []() {
    enum class Local { X = 0, Z = 1 };
    return Local::X;
};

int main() {
    auto x = lambda(); // No error! Why and what type is auto in this case?
    //auto y = Local::X; // Error! Of course!
    using x_type = decltype(x);
    x_type y;
    y = x_type::Z; // can refer to enum members here
    y = x;
}
Run Code Online (Sandbox Code Playgroud)

enum class Locallambda a 类型之外是未知的。

确实如此,但enum class如果相关的命名空间已解析,则可以访问。所以内部<lambda_30560bd1c97ca682d011cd006c362574>::()::Local可以解析到Locallambda 内部,但是在编译之前不可能猜测这个名称,但是我们可以使用decltypeorauto来获取类型。

它是 a ,因此不能是没有强制转换enum class的类型int

正确的。enum class但它仍然以与 an存在于常规classor内部的方式相同的方式存在struct

如果没有已知类型,我如何在 lambda 之外继续使用该值?

这种类型在 lambda 之外的实用性是有限的。它不是一个int,而是有自己独特的类型,因此即使可以间接获得它也没有什么价值。