Lambda Captures C++14

后端 未结 2 1428
被撕碎了的回忆
被撕碎了的回忆 2020-12-16 02:39

I\'ve encountered a notation like:

int x = 4;
auto y = [&r = x, x = x+1]()->int { 
    r += 2;
    return x+2;
}();

Can you explain

2条回答
  •  -上瘾入骨i
    2020-12-16 03:22

    Thanks @chris for the wikipedia reference. What I found is -

    Here is nice explanation who don't know about the old lambda Captures of C++11

    In C++14:


    C++11 lambda functions capture variables declared in their outer scope by value-copy or by reference. This means that value members of a lambda cannot be move-only types. C++14 allows captured members to be initialized with arbitrary expressions. This allows both capture by value-move and declaring arbitrary members of the lambda, without having a correspondingly named variable in an outer scope.

    This is done via the use of an initializer expression:

    auto lambda = [value = 1] {return value;};
    

    The lambda function lambda will return 1, which is what value was initialized with. The declared capture deduces the type from the initializer expression as if by auto.

    This can be used to capture by move, via the use of the standard std::move function:

    std::unique_ptr ptr(new int(10));
    auto lambda = [value = std::move(ptr)] {return *value;};
    

    So the above expression updates x to 6, and initializes y to 7.

提交回复
热议问题