Lambda Captures C++14

后端 未结 2 1425
被撕碎了的回忆
被撕碎了的回忆 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条回答
  • 2020-12-16 03:13

    This example is part of C++14 feature "Lambda capture Initializers", This allows creating lambda captures initialized with arbitrary expressions. Using this reference-captures can have different names than the referenced variable.

    If you run your code :

    int x = 4;
    auto y = [&r = x, x = x+1]()->int { 
        r += 2; //r=6
        return x+2;//5+2
    };
    cout<<y()<<endl; // this will print 7
    
    0 讨论(0)
  • 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<int> 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.

    0 讨论(0)
提交回复
热议问题