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


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

#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 22

2 ответа:

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

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

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