Я хотел бы знать, можно ли создать реальный объект-функтор из выражения лямбда. Я так не думаю, но если нет, то почему?Создание функтора из выражения лямбда
В качестве иллюстрации приведен ниже код, который сортирует точки, используя различные политики для й и у координат:
#include <vector>
#include <functional>
#include <algorithm>
#include <iostream>
struct Point
{
Point(int x, int y) : x(x), y(y) {}
int x, y;
};
template <class XOrder, class YOrder>
struct SortXY :
std::binary_function<const Point&, const Point&, bool>
{
bool operator()(const Point& lhs, const Point& rhs) const
{
if (XOrder()(lhs.x, rhs.x))
return true;
else if (XOrder()(rhs.x, lhs.x))
return false;
else
return YOrder()(lhs.y, rhs.y);
}
};
struct Ascending { bool operator()(int l, int r) const { return l<r; } };
struct Descending { bool operator()(int l, int r) const { return l>r; } };
int main()
{
// fill vector with data
std::vector<Point> pts;
pts.push_back(Point(10, 20));
pts.push_back(Point(20, 5));
pts.push_back(Point(5, 0));
pts.push_back(Point(10, 30));
// sort array
std::sort(pts.begin(), pts.end(), SortXY<Descending, Ascending>());
// dump content
std::for_each(pts.begin(), pts.end(),
[](const Point& p)
{
std::cout << p.x << "," << p.y << "\n";
});
}
Выражения std::sort(pts.begin(), pts.end(), SortXY<Descending, Ascending>());
сорта согласно убыванию значения х, а затем к значениям у восходящих. Это легко понять, и я не уверен, что я действительно хочу использовать лямбда-выражения здесь.
Но если бы я хотел заменить Восходящий/Нисходящий по лямбда-выражениям, как бы вы это сделали? Следующий не действует:
std::sort(pts.begin(), pts.end(), SortXY<
[](int l, int r) { return l>r; },
[](int l, int r) { return l<r; }
>());
Возможно, вам нужна функция 'make_sortXY' для вывода аргументов шаблона? См. 'Make_pair'. Это предполагает, что C++ 0x позволяет безымянный тип лямбды быть аргументом шаблона вообще, я не знаю. –
Также выражение лямбда приводит к * объекту * с помощью 'operator()'. В общем случае для этого требуется экземпляр, потому что там хранятся любые захваченные переменные, и я не уверен, что lambda no-capture определен как особый случай. В частности, имеет ли его тип доступный конструктор no-args, который вы использовали? –
@Steve: спасибо за ваши комментарии. Я понимаю, что вы имеете в виду, кроме последнего предложения во втором комментарии. Что вы имеете в виду? –