2012-11-19 55 views
18

下面的程序不编译:LAMBDA拉姆达的:功能不捕捉

#include <iostream> 
#include <vector> 
#include <functional> 
#include <algorithm> 
#include <cstdlib> 
#include <cmath> 

void asort(std::vector<double>& v, std::function<bool(double, double)> f) 
{ 
    std::sort(v.begin(), v.end(), [](double a, double b){return f(std::abs(a), std::abs(b));}); 
} 

int main() 
{ 
    std::vector<double> v({1.2, -1.3, 4.5, 2.3, -10.2, -3.4}); 
    for (unsigned int i = 0; i < v.size(); ++i) { 
     std::cout<<v[i]<<" "; 
    } 
    std::cout<<std::endl; 
    asort(v, [](double a, double b){return a < b;}); 
    for (unsigned int i = 0; i < v.size(); ++i) { 
     std::cout<<v[i]<<" "; 
    } 
    std::cout<<std::endl; 
    return 0; 
} 

因为:

error : 'f' is not captured 

是什么意思,怎么解决这个问题呢?

回答

37

您在asort()的lambda中使用参数f,但不捕获它。尝试将f添加到捕获列表(更改[]以读取[&f])。

+7

甚至通过引用'[&]来捕获它。 – Cameron

+0

是的,你是对的,我已经更新了我的答案。出于某种原因,我读得太快,并认为'f'是一个函数指针,而不是一个函数对象。 – cdhowie

7

您在lambda中有效地引用了f,它是外部作用域中的变量。您应该将其捕获到捕获列表中(最简单的方法可能是参考[& f]或[&]以通过引用捕获所有内容,就像您立即使用它一样)。

在另一个说明中,std :: function在执行类型擦除时会有一些开销,在你的情况下,这里最好引入一个模板类型。