Namensräume
Varianten
Aktionen

std::multiplies<void>

Von cppreference.com
< cpp‎ | utility‎ | functional
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
Funktionsobjekte
Funktionsaufruf
(C++17)(C++23)
Identitätsfunktions-Objekt
(C++20)
Transparente Operator-Wrapper
(C++14)
(C++14)
(C++14)
multiplies<>
(C++14)  
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)

Alte Binder und Adaptoren
(bis C++17*)
(bis C++17*)
(bis C++17*)
(bis C++17*)
(bis C++17*)(bis C++17*)(bis C++17*)(bis C++17*)
(bis C++20*)
(bis C++20*)
(bis C++17*)(bis C++17*)
(bis C++17*)(bis C++17*)

(bis C++17*)
(bis C++17*)(bis C++17*)(bis C++17*)(bis C++17*)
(bis C++20*)
(bis C++20*)
 
Definiert in der Header-Datei <functional>
template<>
class multiplies<void>;
(seit C++14)

std::multiplies<void> ist eine Spezialisierung von std::multiplies mit abgeleitetem Parameter- und Rückgabetyp.

Inhalt

[edit] Member types

Typ Definition
is_transparent nicht spezifiziert

[edit] Member functions

operator()
gibt das Produkt zweier Argumente zurück
(öffentliche Memberfunktion)

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

template< class T, class U >

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

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

Gibt das Produkt von lhs und rhs zurück.

Parameter

lhs, rhs - Werte zum Multiplizieren

Rückgabewert

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

[edit] Beispiel

#include <complex>
#include <functional>
#include <iostream>
 
int main()
{
    auto complex_multiplies = std::multiplies<void>{}; // “void” can be omitted
    constexpr std::complex z1{1.0, 2.0}, z2{3.0, 4.0};
 
    std::cout << std::showpos
              << complex_multiplies(z1, z2) << ' ' << z1 * z2 << '\n'
              << complex_multiplies(z1, 5.) << ' ' << z1 * 5. << '\n'
              << complex_multiplies(5., z1) << ' ' << 5. * z1 << '\n';
}

Ausgabe

(-5,+10) (-5,+10)
(+5,+10) (+5,+10)
(+5,+10) (+5,+10)