weiß ich, das ein wenig alt ..
Aber ich wollte noch hinzufügen:
Lambda Ausdruck (auch erfasst sind) als Funktionszeiger behandelt werden können!
Es ist schwierig, weil ein Lambda-Ausdruck keine einfache Funktion ist. Es ist eigentlich ein Objekt mit einem Operator().
Wenn Sie kreativ sind, können Sie dies verwenden! Denken Sie an eine "Funktion" -Klasse im Stil der Std :: -Funktion. Wenn Sie das Objekt speichern!
Sie können auch den Funktionszeiger verwenden.
den Funktionszeiger zu verwenden, können Sie die folgende verwenden:
int first = 5;
auto lambda = [=](int x, int z) {
return x + z + first;
};
int(decltype(lambda)::*ptr)(int, int)const = &decltype(lambda)::operator();
std::cout << "test = " << (lambda.*ptr)(2, 3) << std::endl;
eine Klasse zu erstellen, die wie eine Arbeit beginnen kann „std :: function“ Ich werde nur kurz Beispiel tun. Zuerst müssen Sie eine Klasse/Struktur als Dosenspeicherobjekt und Funktionszeiger auch benötigen Sie einen Operator(), um sie auszuführen:
// OT => Object Type
// RT => Return Type
// A ... => Arguments
template<typename OT, typename RT, typename ... A>
struct lambda_expression {
OT _object;
RT(OT::*_function)(A...)const;
lambda_expression(const OT & object)
: _object(object), _function(&decltype(_object)::operator()) {}
RT operator() (A ... args) const {
return (_object.*_function)(args...);
}
};
Damit Sie jetzt gefangen laufen, noncaptured lambdas, genau wie Sie das Original verwenden :
auto capture_lambda() {
int first = 5;
auto lambda = [=](int x, int z) {
return x + z + first;
};
return lambda_expression<decltype(lambda), int, int, int>(lambda);
}
auto noncapture_lambda() {
auto lambda = [](int x, int z) {
return x + z;
};
return lambda_expression<decltype(lambda), int, int, int>(lambda);
}
void refcapture_lambda() {
int test;
auto lambda = [&](int x, int z) {
test = x + z;
};
lambda_expression<decltype(lambda), void, int, int>f(lambda);
f(2, 3);
std::cout << "test value = " << test << std::endl;
}
int main(int argc, char **argv) {
auto f_capture = capture_lambda();
auto f_noncapture = noncapture_lambda();
std::cout << "main test = " << f_capture(2, 3) << std::endl;
std::cout << "main test = " << f_noncapture(2, 3) << std::endl;
refcapture_lambda();
system("PAUSE");
return 0;
}
Dieser Code funktioniert mit VS2015 Hoffe, es hilft:)
Greets!
Edit: entfernt Nadeln FP Vorlage entfernt Funktionszeiger Parameter,
-Update 04.07.17 bis lambda_expression umbenannt:
template <typename CT, typename ... A> struct function
: public function<decltype(&CT::operator())(A...)> {};
template <typename C> struct function<C> {
private:
C mObject;
public:
function(const C & obj)
: mObject(obj) {}
template<typename... Args> typename
std::result_of<C(Args...)>::type operator()(Args... a) {
return this->mObject.operator()(a...);
}
template<typename... Args> typename
std::result_of<const C(Args...)>::type operator()(Args... a) const {
return this->mObject.operator()(a...);
}
};
namespace make {
template<typename C> auto function(const C & obj) {
return ::function<C>(obj);
}
}
int main(int argc, char ** argv) {
auto func = make::function([](int y, int x) { return x*y; });
std::cout << func(2, 4) << std::endl;
system("PAUSE");
return 0;
}
Lambda kann nur dann zum Funktionszeiger zurückkehren, wenn sie nichts erfassen. – Jarod42
http://blogs.msdn.com/b/oldnewthing/archive/2015/02/20/10594680.aspx – BoBTFish