Пример использования лямбда-функции как значения поля класса — различия между версиями
Материал из Вики ИТ мехмата ЮФУ
Ulysses (обсуждение | вклад) |
Ulysses (обсуждение | вклад) (+ замечание про [=]) |
||
Строка 40: | Строка 40: | ||
} | } | ||
</source> | </source> | ||
+ | |||
+ | |||
+ | == Замечание о <tt>[=]</tt> == | ||
+ | |||
+ | Для лямбда-функций требуется писать ''кое-что'' внутри квадратных скобок, если внутри лямбда-функции используются переменные из '''контекста''' определения этой функции. В нашем примере лямбда-функция использует <tt>this</tt>. Значок <tt>=</tt> означает, что все захватываемые из контекста переменные передаются по значению. Если вместо <tt>=</tt> написать <tt>&</tt>, то все захваченные переменные будут передаваться по ссылке. Также можно указывать тип захвата индивидуально для каждой переменной. В нашем примере захватывается только указатель this, а указатели обычно всегда передаются по значению (в обычных функциях тоже), потому пишем <tt>=</tt>. |
Версия 17:26, 5 декабря 2014
#include <functional>
#include <iostream>
using std::cout;
using std::endl;
class Bar {
public:
void f(int n) { cout << "Bar::f(" << n << ")" << endl; }
void g(int n) { cout << "Bar::g(" << n << ")" << endl; }
};
class Foo {
Bar b;
public:
Foo() { setF(); }
// функциональное поле: будет хранить функцию от одного аргумент int и возвращать void
std::function<void(int)> alloc;
void setF() {
alloc = [=](int N){ this->b.f(N); }; // лямбда-функция (то есть безымянная функция) от одного int-аргумента N
// вызывает b.f(N)
}
void setG() {
alloc = [=](int N){ this->b.g(N); };
}
};
int main()
{
Foo f;
f.alloc(42); // >>> Bar::f(42)
f.setG();
f.alloc(43); // >>> Bar::g(43)
}
Замечание о [=]
Для лямбда-функций требуется писать кое-что внутри квадратных скобок, если внутри лямбда-функции используются переменные из контекста определения этой функции. В нашем примере лямбда-функция использует this. Значок = означает, что все захватываемые из контекста переменные передаются по значению. Если вместо = написать &, то все захваченные переменные будут передаваться по ссылке. Также можно указывать тип захвата индивидуально для каждой переменной. В нашем примере захватывается только указатель this, а указатели обычно всегда передаются по значению (в обычных функциях тоже), потому пишем =.