Sie std::function
verwenden können, beispielsweise annehmen, dass es void
Funktion ist und bekommt zwei int
:
class Bot
{
private:
using Lambda = std::function<void(int, int) >;
Lambda lambda;
public:
Bot(const Lambda &l) : lambda(l)
{
}
void update()
{
//dosomething...;
lambda(1, 2);
}
};
int main()
{
Bot bot ([](int x, int y){ cout << x+y << endl; });
bot.update();
}
Weitere generic:
template <typename L>
class Bot
{
private:
L lambda;
public:
Bot(const L &l) : lambda(l)
{
}
void update()
{
//dosomething...;
lambda(1, 2);
}
};
int main()
{
Bot<std::function<void(int,int)>> bot (
[](int x, int y){ cout << x+y << endl; }
);
bot.update();
}
Vorlage basiert:
template <typename L>
struct Bot
{
private:
L lambda;
public:
Bot(const L &l) : lambda{l} {}
void update() { lambda(1,2); }
};
int main()
{
auto l = [](int x, int y){ std::cout << x + y << std::endl; };
Bot<decltype(l)> bot(l);
bot.update();
}
BTW verwenden, wird es geschrieben "Lambda" :) – StilesCrisis
Jeder Lambda-Ausdruck eine einzigartige Art hat, so dass ich glaube nicht, es ist möglich. Betrachte 'auto x = [] {}; Automatisch y = [] {}; std :: is_same {} // ergibt false'. –
dyp
@StilesCrisis Ah, danke :) in den frühen Tagen dachte ich, es wäre buchstabiert lambada – user2796729