std::bit_not

From cppreference.com
< cpplrm; | utilitylrm; | functional
Function objects
Function wrappers
(C++11)
(C++11)
Bind
(C++11)
Function invocation
(C++17)
Identity function object
(C++20)
Reference wrappers
(C++11)(C++11)
Operator wrappers
Negators
(C++17)
Searchers
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)
(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)
Defined in header <functional>
template< class T = void >
struct bit_not;
(since C++14)

Function object for performing bitwise NOT. Effectively calls operator~ on type T.

Specializations

The standard library provides a specialization of std::bit_not when T is not specified, which leaves the parameter types and return type to be deduced.

function object implementing ~x deducing argument and return types
(class template specialization)


Member types

Type Definition
result_type(deprecated in C++17) T
argument_type(deprecated in C++17) T
(until C++20)

Member functions

operator()
returns the result of bitwise NOT of its argument
(public member function)

std::bit_not::operator()

constexpr T operator()( const T& arg ) const;

Returns the result of bitwise NOT of arg.

Parameters

arg - value to compute bitwise NOT of

Return value

The result of ~arg.

Exceptions

(none)

Possible implementation

constexpr T operator()(const T& arg) const 
{
    return ~arg;
}