Пространства имён
Варианты
Действия

std::unary_function

Материал из cppreference.com
< cpp‎ | utility‎ | functional
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм(C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования(C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
Объекты функции
Функции обёртки
(C++11)
(C++11)
Применение частичных функций
(C++20)(C++23)
(C++11)
Вызов функции
(C++17)(C++23)
Объект идентичности функции
(C++20)
Обёртки ссылок
(C++11)(C++11)
Прозрачные обёртки операторов
(C++14)
(C++14)
(C++14)
(C++14)  
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
Отрицатели
(C++17)
Искатели
Ограниченные компараторы
Старые привязки и адаптеры
unary_function
(до C++17*)
(до C++17*)
(до C++17*)
(до C++17*)
(до C++17*)(до C++17*)(до C++17*)(до C++17*)
(до C++20*)
(до C++20*)
(до C++17*)(до C++17*)
(до C++17*)(до C++17*)

(до C++17*)
(до C++17*)(до C++17*)(до C++17*)(до C++17*)
(до C++20*)
(до C++20*)
 
Определено в заголовочном файле <functional>
template<typename ArgumentType, typename ResultType>
struct unary_function;
(устарело в C++11)
(удалено в C++17)

unary_function это базовый класс для создания объектов-функций с одним аргументом.

unary_function не определяет operator(); ожидается, что его будут определять производные классы. unary_function предоставляет только два типа argument_type и result_type, определяемые параметрами шаблона.

Некоторые адаптеры объектов функций стандартной библиотеки, такие как std::not1, требуют, чтобы объекты функций, которые они адаптируют, имели некоторые определённые типы; std::not1 требует, чтобы адаптируемый объект функции имел тип с именем argument_type. Создание объектов-функций, которые принимают один аргумент из unary_function, это простой способ сделать их совместимыми с этими адаптерами.

unary_function устарел в C++11.

[править]Типы элементы

Тип Определение
argument_typeArgumentType
result_typeResultType

[править]Пример

#include <algorithm>#include <functional>#include <iostream>#include <vector>   struct less_than_7 : std::unary_function<int, bool>{bool operator()(int i)const{return i <7;}};   int main(){std::vector<int> v;for(int i =0; i <10;++i) v.push_back(i);   std::cout<<std::count_if(v.begin(), v.end(), std::not1(less_than_7()));   /* Решение C++11: // Приведение к std::function<bool (int)> каким-то образом, даже с лямбдой std::cout << std::count_if(v.begin(), v.end(), std::not1(std::function<bool (int)>([](int i){ return i < 7; })) ); */}

Вывод:

3

[править]Смотрите также

(C++11)
обёртывает вызываемый объект любого конструируемого копированием типа с указанной сигнатурой вызова функции
(шаблон класса)[править]
обёртывает вызываемый объект любого типа с указанной сигнатурой вызова функции
(шаблон класса)[править]
(устарело в C++11)(удалено в C++17)
создаёт совместимую с адаптером обёртку функционального объекта из указателя на функцию
(шаблон функции)[править]
(устарело в C++11)(удалено в C++17)
совместимая с адаптером обёртка для указателя на унарную функцию
(шаблон класса)[править]
(deprecated in C++11)(удалено в C++17)
совместимый с адаптером базовый класс бинарной функции
(шаблон класса)[править]
close