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* )
Défini dans l'en-tête <functional>
template < class Arg, class Result >

std:: pointer_to_unary_function < Arg,Result >

ptr_fun ( Result ( * f ) ( Arg ) ) ;
(1) (obsolète en C++11)
(supprimé en C++17)
template < class Arg1, class Arg2, class Result >

std:: pointer_to_binary_function < Arg1,Arg2,Result >

ptr_fun ( Result ( * f ) ( Arg1, Arg2 ) ) ;
(2) (obsolète en C++11)
(supprimé en C++17)

Crée un objet wrapper de fonction (soit std:: pointer_to_unary_function ou std:: pointer_to_binary_function ), en déduisant le type cible à partir des arguments template.

1) Appelle effectivement std:: pointer_to_unary_function < Arg,Result > ( f ) .
2) Appelle effectivement std:: pointer_to_binary_function < Arg1,Arg2,Result > ( f ) .

Cette fonction et les types associés sont dépréciés à partir de C++11 au profit des versions plus générales std::function et std::ref , qui créent toutes deux des objets fonction compatibles avec les adaptateurs d'appel à partir de fonctions simples.

Table des matières

Paramètres

f - pointeur vers une fonction pour laquelle créer un wrapper

Valeur de retour

Un objet fonction encapsulant f .

Exceptions

Peut lever des exceptions définies par l'implémentation.

Exemple

#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
}

Sortie :

Hll, wrld!

Voir aussi

(C++11)
enveloppe copiable de tout objet appelable copiable
(modèle de classe)
enveloppe non copiable de tout objet appelable qui supporte les qualificateurs dans une signature d'appel donnée
(modèle de classe)
(C++17) (C++23)
invoque tout Callable objet avec les arguments donnés et possibilité de spécifier le type de retour (depuis C++23)
(modèle de fonction)
(C++17)
crée un objet fonction qui retourne le complément du résultat de l'objet fonction qu'il contient
(modèle de fonction)