std::logical_and<void>

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 logical_and<void>;
(since C++14)

std::logical_and<> is a specialization of std::logical_and with parameter and return type deduced.

Member types

Member type Definition
is_transparent /* unspecified */

Member functions

operator()
applies operator&& to lhs and rhs
(public member function)

std::logical_and<>::operator()

template< class T, class U>

constexpr auto operator()( T&& lhs, U&& rhs ) const

-> decltype(std::forward<T>(lhs) && std::forward<U>(rhs));

Returns the result of lhs && rhs.

Parameters

lhs, rhs - values to AND

Return value

The result of lhs && rhs.

Notes

The member type is_transparent indicates to the caller that this function object is a transparent function object: it accepts arguments of arbitrary types and uses perfect forwarding, which avoids unnecessary copying and conversion when the function object is used in heterogeneous context, or with rvalue arguments. In particular, template functions such as std::set::find and std::set::lower_bound make use of this member type on their Compare types.

Example