Namespaces
Variants

std:: ptr_fun

From cppreference.net
Utilities library
Function objects
Function invocation
(C++17) (C++23)
Identity function object
(C++20)
Old binders and adaptors
( until C++17* )
( until C++17* )
ptr_fun
( until C++17* )
( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
( until C++17* ) ( until C++17* )
( until C++17* ) ( until C++17* )

( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
Definiert im Header <functional>
template < class Arg, class Result >

std:: pointer_to_unary_function < Arg,Result >

ptr_fun ( Result ( * f ) ( Arg ) ) ;
(1) (veraltet in C++11)
(entfernt in C++17)
template < class Arg1, class Arg2, class Result >

std:: pointer_to_binary_function < Arg1,Arg2,Result >

ptr_fun ( Result ( * f ) ( Arg1, Arg2 ) ) ;
(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.

1) Ruft effektiv std:: pointer_to_unary_function < Arg,Result > ( f ) auf.
2) Ruft effektiv std:: pointer_to_binary_function < Arg1,Arg2,Result > ( f ) auf.

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)
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)