2012-11-19 81 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在執行類型擦除時會有一些開銷,在你的情況下,這裏最好引入一個模板類型。