无法通过引用捕获Lambda中的成员变量

时间:2018-07-13 09:46:02

标签: c++ c++11 lambda c++14

请考虑以下代码段:

#include <map>
#include <string>
#include <set>
#include <algorithm>
#include <cmath>

using TargetsType = std::map<float, std::string>;
using TimesType = std::set<float>;

void foo (const TargetsType& targets,
          const TimesType& times)
{
    for (const auto& target : targets)
    {
        // fails to compile
        TimesType::const_iterator iter1 = std::find_if(times.begin(),
                                                       times.end(),
                                                       [&(target.first)](float item) 
                                                       {
                                                           return std::fabs(item - target.first) < 0.1f;
                                                       });

        // compiles OK
        TimesType::const_iterator iter2 = std::find_if(times.begin(),
                                                       times.end(),
                                                       [&](float item) 
                                                       {
                                                           return std::fabs(item - target.first) < 0.1f;
                                                       });
    }
}

iter1的声明无法编译,并出现以下错误:

error: expected ',' before '(' token

但是声明iter2可以。

有人可以解释为什么第一个声明不编译吗?

1 个答案:

答案 0 :(得分:10)

[&(target.first)](float item) {
    return std::fabs(item - target.first) < 0.1f;
}

您不能做[&(target.first)]。即使没有括号,您也无法捕获这样的单个成员变量。您需要使用C ++ 14的捕获init:

[&first = target.first](float item) {
    return std::fabs(item - first) < 0.1f;
}

或者,在第二个lambda之后,仅捕获target

[&target](float item) {
    return std::fabs(item - target.first) < 0.1f;
}