Namespaces
Variants

std:: not1

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* )
( until C++17* )
( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
not1
( 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 Predicate >
std:: unary_negate < Predicate > not1 ( const Predicate & pred ) ;
(до C++14)
template < class Predicate >
constexpr std:: unary_negate < Predicate > not1 ( const Predicate & pred ) ;
(начиная с C++14)
(устарело в C++17)
(удалено в C++20)

std::not1 — это вспомогательная функция для создания функционального объекта, возвращающего дополнение переданной унарной предикатной функции. Создаваемый функциональный объект имеет тип std:: unary_negate < Predicate > .

Унарный тип предиката должен определять тип-член argument_type , который может быть преобразован в тип параметра предиката. Унарные функциональные объекты, полученные из std::ref , std::cref , std::negate , std::logical_not , std::mem_fn , std::function , std::hash , или из другого вызова std::not1 имеют этот тип определённым, как и функциональные объекты, унаследованные от устаревшего std::unary_function .

Содержание

Параметры

pred - унарный предикат

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

std::not1 возвращает объект типа std:: unary_negate < Predicate > , созданный с помощью pred .

Исключения

(нет)

Пример

#include <algorithm>
#include <functional>
#include <iostream>
#include <iterator>
#include <numeric>
#include <vector>
struct LessThan7 : std::unary_function<int, bool>
{
    bool operator()(int i) const { return i < 7; }
};
int main()
{
    std::vector<int> v(10);
    std::iota(std::begin(v), std::end(v), 0);
    std::cout << std::count_if(begin(v), end(v), std::not1(LessThan7())) << '\n';
    // то же самое с использованием std::function
    std::function<bool(int)> less_than_9 = [](int x) { return x < 9; };
    std::cout << std::count_if(begin(v), end(v), std::not1(less_than_9)) << '\n';
}

Вывод:

3
1

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

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