std:: ptr_fun
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Old binders and adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Definiert im Header
<functional>
|
||
|
template
<
class
Arg,
class
Result
>
std::
pointer_to_unary_function
<
Arg,Result
>
|
(1) |
(veraltet in C++11)
(entfernt in C++17) |
|
template
<
class
Arg1,
class
Arg2,
class
Result
>
std::
pointer_to_binary_function
<
Arg1,Arg2,Result
>
|
(2) |
(veraltet in C++11)
(entfernt in C++17) |
Erstellt ein Funktionswrapper-Objekt (entweder std:: pointer_to_unary_function oder std:: pointer_to_binary_function ), wobei der Zieltyp aus den Template-Argumenten abgeleitet wird.
Diese Funktion und die zugehörigen Typen sind seit C++11 als veraltet gekennzeichnet und wurden durch die allgemeineren std::function und std::ref ersetzt, die beide aufrufbare Adapter-kompatible Funktionsobjekte aus einfachen Funktionen erzeugen.
Inhaltsverzeichnis |
Parameter
| f | - | Zeiger auf eine Funktion, für die ein Wrapper erstellt werden soll |
Rückgabewert
Ein Funktionsobjekt, das f umschließt.
Exceptions
Kann implementierungsdefinierte Ausnahmen auslösen.
Beispiel
#include <algorithm> #include <functional> #include <iostream> #include <string_view> constexpr bool is_vowel(char c) { return std::string_view{"aeoiuAEIOU"}.find(c) != std::string_view::npos; } int main() { std::string_view s = "Hello, world!"; std::ranges::copy_if(s, std::ostreambuf_iterator<char>(std::cout), std::not1(std::ptr_fun(is_vowel))); #if 0 // C++11 alternatives: std::not1(std::cref(is_vowel))); std::not1(std::function<bool(char)>(is_vowel))); [](char c) { return !is_vowel(c); }); // C++17 alternatives: std::not_fn(is_vowel)); #endif }
Ausgabe:
Hll, wrld!
Siehe auch
|
(C++11)
|
kopierbarer Wrapper für jedes kopierkonstruierbare aufrufbare Objekt
(Klassentemplate) |
|
(C++23)
|
Nur-verschiebbarer Wrapper für jedes aufrufbare Objekt, das Qualifier in einer gegebenen Aufrufsignatur unterstützt
(Klassentemplate) |
|
(C++17)
(C++23)
|
ruft jedes
Callable
Objekt mit gegebenen Argumenten auf
mit Möglichkeit zur Spezifikation des Rückgabetyps
(since C++23)
(Funktionstemplate) |
|
(C++17)
|
erstellt ein Funktionsobjekt, das das Komplement des Ergebnisses des von ihm gehaltenen Funktionsobjekts zurückgibt
(Funktionstemplate) |