Лямбда лямбды: функция не захвачена
Следующая программа не компилируется:
#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
Что это значит и как решить проблему ?2 ответа:
Вы используете параметр
f
в лямбде внутриasort()
, но не захватываете его. Попробуйте добавитьf
в список захвата (измените[]
на чтение[&f]
).
Вы фактически ссылаетесь на переменную f, которая является переменной во внешней области видимости, в вашей лямбде. Вы должны захватить его в свой список захвата (простейший, вероятно, по ссылке [&f], или [ & ], чтобы захватить все по ссылке, так как вы используете его немедленно).
С другой стороны, функция std::имеет некоторые накладные расходы, поскольку она выполняет стирание типов, в вашем случае здесь, возможно, лучше ввести тип шаблона.