Лямбда лямбда: функция не захватывается

Следующая программа не компилируется:

#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

Что это значит и как решить проблему?

24

Решение

Вы используете f параметр в лямбда внутри asort(), но вы не захватываете это. Попробуйте добавить f в список захвата (изменить [] читать [&f]).

46

Другие решения

Вы эффективно ссылаетесь на f, которая является переменной во внешней области видимости в вашей лямбде. Вы должны захватить его в свой список захвата (самый простой, вероятно, по ссылке [&за [&], чтобы захватить все по ссылке, так как вы используете это немедленно).

С другой стороны, std :: function имеет некоторые издержки, так как выполняет стирание типа, в вашем случае здесь может быть лучше ввести тип шаблона.

7

По вопросам рекламы [email protected]