这个lambda捕获问题是一个gcc编译器错误吗?

Tom*_*son 3 c++ lambda gcc g++ c++11

最低工作示例:

#include <iostream>
#include <memory>
#include <string>

int main()
{
    std::shared_ptr<std::string> i = std::make_shared<std::string>("foo");

    auto f = [=]()
        {
            i.reset();
            std::cout << i.get() << "\n";
        };

    std::cout << i.use_count() << "\n";
    f();
    std::cout << i.use_count() << "\n";
}
Run Code Online (Sandbox Code Playgroud)

编译错误:

$ g++ -std=c++11 /tmp/foo.cpp 
/tmp/foo.cpp: In lambda function:
/tmp/foo.cpp:11:12: error: passing ‘const std::shared_ptr<std::basic_string<char> >’ as ‘this’ argument of ‘void std::__shared_ptr<_Tp, _Lp>::reset() [with _Tp = std::basic_string<char>; __gnu_cxx::_Lock_policy _Lp = (__gnu_cxx::_Lock_policy)2u]’ discards qualifiers [-fpermissive]
    i.reset();
Run Code Online (Sandbox Code Playgroud)

我认为i应该被捕获为一个值,但它似乎被捕获为一个const值.

编译器版本:

g++ (GCC) 4.9.2 20141101 (Red Hat 4.9.2-1)
Run Code Online (Sandbox Code Playgroud)

Col*_*mbo 7

shared_ptr是闭包对象的成员.并且operator()标记了const.
因此i,您无法修改,即调用非const成员函数,例如reset.

尝试

auto f = [=]() mutable
{
    i.reset();
    std::cout << i.get() << "\n";
};
Run Code Online (Sandbox Code Playgroud)