std::placeholders::_1, std::placeholders::_2, ..., std::placeholders::_N
| Definiert in der Header-Datei <functional> |
||
| /*siehe unten*/ _1; /*siehe unten*/ _2; |
||
Der std::placeholders Namespace enthält die Platzhalterobjekte [_1, ..., _N], wobei N eine implementierungsdefinierte maximale Anzahl ist.
Wenn Platzhalterobjekte als Argument in einem std::bind Ausdruck verwendet werden, werden sie im generierten Funktions-Objekt gespeichert. Wenn dieses Funktions-Objekt mit ungebundenen Argumenten aufgerufen wird, wird jeder Platzhalter _N durch das entsprechende N-te ungebundene Argument ersetzt.
|
Jeder Platzhalter ist so deklariert, als ob durch extern /*unspecified*/ _1;. |
(bis C++17) |
|
Implementierungen werden ermutigt, die Platzhalter so zu deklarieren, als ob durch inline constexpr /*unspecified*/ _1;, obwohl die Deklaration durch extern /*unspecified*/ _1; vom Standard noch zugelassen wird. |
(seit C++17) |
Die Typen der Platzhalterobjekte sind DefaultConstructible und CopyConstructible. Ihre Standard-Kopier-/Verschiebekonstruktoren werfen keine Ausnahmen. Für jeden Platzhalter _N ist der Typ std::is_placeholder<decltype(_N)> definiert, wobei std::is_placeholder<decltype(_N)> von std::integral_constant<int, N> abgeleitet ist.
[bearbeiten] Beispiel
Der folgende Code zeigt die Erstellung von Funktions-Objekten mit Platzhalter-Argumenten.
#include <functional> #include <iostream> #include <string> void goodbye(const std::string& s) { std::cout << "Goodbye " << s << '\n'; } class Object { public: void hello(const std::string& s) { std::cout << "Hello " << s << '\n'; } }; int main() { using namespace std::placeholders; using ExampleFunction = std::function<void(const std::string&)>; Object instance; std::string str("World"); ExampleFunction f = std::bind(&Object::hello, &instance, _1); f(str); // equivalent to instance.hello(str) f = std::bind(&goodbye, std::placeholders::_1); f(str); // equivalent to goodbye(str) auto lambda = [](std::string pre, char o, int rep, std::string post) { std::cout << pre; while (rep-- > 0) std::cout << o; std::cout << post << '\n'; }; // binding the lambda: std::function<void(std::string, char, int, std::string)> g = std::bind(&decltype(lambda)::operator(), &lambda, _1, _2, _3, _4); g("G", 'o', 'o'-'g', "gol"); }
Ausgabe
Hello World Goodbye World Goooooooogol
[bearbeiten] Siehe auch
| (C++11) |
bindet ein oder mehrere Argumente an ein Funktions-Objekt (Funktions-Template) |
| (C++11) |
zeigt an, dass ein Objekt ein Standard-Platzhalter ist oder als solcher verwendet werden kann (Klassen-Template) |
| (C++11) |
Platzhalter zum Überspringen eines Elements beim Entpacken eines tuple mit tie(constant) |