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* )
Определено в заголовочном файле <functional>
template < class Arg, class Result >

std:: pointer_to_unary_function < Arg,Result >

ptr_fun ( Result ( * f ) ( Arg ) ) ;
(1) (устарело в C++11)
(удалено в C++17)
template < class Arg1, class Arg2, class Result >

std:: pointer_to_binary_function < Arg1,Arg2,Result >

ptr_fun ( Result ( * f ) ( Arg1, Arg2 ) ) ;
(2) (устарело в C++11)
(удалено в C++17)

Создает объект-обертку функции (либо std:: pointer_to_unary_function либо std:: pointer_to_binary_function ), выводя целевой тип из аргументов шаблона.

1) Эффективно вызывает std:: pointer_to_unary_function < Arg,Result > ( f ) .
2) Эффективно вызывает std:: pointer_to_binary_function < Arg1,Arg2,Result > ( f ) .

Эта функция и связанные с ней типы устарели, начиная с C++11, в пользу более универсальных std::function и std::ref , которые создают совместимые с адаптерами функциональные объекты из обычных функций.

Содержание

Параметры

f - указатель на функцию, для которой создается обертка

Возвращаемое значение

Объект-функция, оборачивающий f .

Исключения

Может генерировать исключения, определяемые реализацией.

Пример

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

Вывод:

Hll, wrld!

Смотрите также

(C++11)
копируемая обёртка для любого копируемого вызываемого объекта
(шаблон класса)
перемещаемая обёртка для любого вызываемого объекта, поддерживающего квалификаторы в заданной сигнатуре вызова
(шаблон класса)
(C++17) (C++23)
вызывает любой Callable объект с заданными аргументами с возможностью указания возвращаемого типа (начиная с C++23)
(шаблон функции)
(C++17)
создаёт функциональный объект, возвращающий дополнение результата хранимого функционального объекта
(шаблон функции)