std::multiplies<void>
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <functional>
|
||
template<> class multiplies<void>; |
(начиная с C++14) | |
std::multiplies<> является специализацией std::multiplies с выведенным типом параметра и возвращаемого значения.
Типы элементы
| Тип элемент | Определение |
is_transparent
|
/* неопределено */ |
Функции-элементы
| возвращает произведение двух аргументов (public функция-элемент) |
std::multiplies<>::operator()
<tbody> </tbody> template< class T, class U> constexpr auto operator()( T&& lhs, U&& rhs ) const -> decltype(std::forward<T>(lhs) * std::forward<U>(rhs)); |
||
Возвращает результат умножения lhs на rhs (или что-то другое, для чего перегружен operator*).
Параметры
| lhs, rhs | — | значения для умножения |
Возвращаемое значение
Результат lhs * rhs.
Примечание
Тип элемент is_transparent указывает вызывающему объекту, что этот функциональный объект является прозрачным: он принимает аргументы произвольных типов и использует идеальную переадресацию, которая позволяет избежать ненужного копирования и преобразования, когда функциональный объект используется в разнородном контексте или с аргументами rvalue. В частности, шаблонные функции, такие как std::set::find и std::set::lower_bound , используют этот тип элемента в своих типах Compare.
Пример
Запустить этот код
#include <complex>
#include <functional>
#include <iostream>
int main()
{
constexpr std::complex z1{1., 2.}, z2{3., 4.};
std::cout << std::showpos
<< std::multiplies{}(z1, z2) << ' ' << z1 * z2 << '\n'
<< std::multiplies{}(z1, 5.) << ' ' << z1 * 5. << '\n'
<< std::multiplies{}(5., z1) << ' ' << 5. * z1 << '\n'
;
}
Вывод:
(-5,+10) (-5,+10)
(+5,+10) (+5,+10)
(+5,+10) (+5,+10)