Namespaces
Variants

std:: modulus<void>

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* )
( 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* )
Défini dans l'en-tête <functional>
template <>
class modulus < void > ;
(depuis C++14)

std:: modulus < void > est une spécialisation de std::modulus avec déduction du type de paramètre et de retour.

Table des matières

Types imbriqués

Type imbriqué Définition
is_transparent unspecified

Fonctions membres

operator()
renvoie le module de deux arguments
(fonction membre publique)

std::modulus<void>:: operator()

template < class T, class U >

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

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

Retourne le reste de la division de lhs par rhs .

Paramètres

lhs, rhs - valeurs à diviser

Valeur de retour

std:: forward < T > ( lhs ) % std:: forward < U > ( rhs ) .

Exemple

#include <functional>
#include <iostream>
struct M
{
    M(int x) { std::cout << "M(" << x << ");\n"; }
    M() {}
};
auto operator%(M, M) { std::cout << "operator%(M, M);\n"; return M{}; }
auto operator%(M, int) { std::cout << "operator%(M, int);\n"; return M{}; }
auto operator%(int, M) { std::cout << "operator%(int, M);\n"; return M{}; }
int main()
{
    M m;
    // 42 est converti en un objet temporaire M{42}
    std::modulus<M>{}(m, 42);    // appelle operator%(M, M)
    // aucun objet temporaire
    std::modulus<void>{}(m, 42); // appelle operator%(M, int)
    std::modulus<void>{}(42, m); // appelle operator%(int, M)
}

Sortie :

M(42);
operator%(M, M);
operator%(M, int);
operator%(int, M);