operator+,-,*,/,%,&,|,^,<<,>>,&&,|| (std::valarray)

< cpp‎ | numeric‎ | valarray
 
 
数值库
常用数学函数
数学特殊函数 (C++17)
数学常数 (C++20)
浮点环境 (C++11)
复数
数值数组
伪随机数生成
编译时有理数算术 (C++11)
数值算法
(C++17)
(C++17)
插值
(C++20)
(C++20)
通用数值运算
(C++11)
位操作
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
 
 
定义于头文件 <valarray>
template <class T>

std::valarray<T> operator+ (const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator- (const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator* (const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator/ (const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator% (const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator& (const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator| (const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator^ (const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator<<(const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator>>(const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>
std::valarray<bool> operator&&(const std::valarray<T>& lhs, const std::valarray<T>& rhs);
template <class T>

std::valarray<bool> operator||(const std::valarray<T>& lhs, const std::valarray<T>& rhs);
(1)
template <class T>

std::valarray<T> operator+ (const typename std::valarray<T>::value_type & val,
                            const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator- (const typename std::valarray<T>::value_type & val,
                            const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator* (const typename std::valarray<T>::value_type & val,
                            const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator/ (const typename std::valarray<T>::value_type & val,
                            const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator% (const typename std::valarray<T>::value_type & val,
                            const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator& (const typename std::valarray<T>::value_type & val,
                            const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator| (const typename std::valarray<T>::value_type & val,
                            const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator^ (const typename std::valarray<T>::value_type & val,
                            const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator<<(const typename std::valarray<T>::value_type & val,
                            const std::valarray<T>& rhs);
template <class T>
std::valarray<T> operator>>(const typename std::valarray<T>::value_type & val,
                            const std::valarray<T>& rhs);
template <class T>
std::valarray<bool> operator&&(const typename std::valarray<T>::value_type & val,
                               const std::valarray<T>& rhs);
template <class T>
std::valarray<bool> operator||(const typename std::valarray<T>::value_type & val,

                               const std::valarray<T>& rhs);
(2)
template <class T>

std::valarray<T> operator+ (const std::valarray<T>& lhs,
                            const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<T> operator- (const std::valarray<T>& lhs,
                            const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<T> operator* (const std::valarray<T>& lhs,
                            const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<T> operator/ (const std::valarray<T>& lhs,
                            const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<T> operator% (const std::valarray<T>& lhs,
                            const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<T> operator& (const std::valarray<T>& lhs,
                            const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<T> operator| (const std::valarray<T>& lhs,
                            const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<T> operator^ (const std::valarray<T>& lhs,
                            const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<T> operator<<(const std::valarray<T>& lhs,
                            const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<T> operator>>(const std::valarray<T>& lhs,
                            const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<bool> operator&&(const std::valarray<T>& lhs,
                               const typename std::valarray<T>::value_type & val);
template <class T>
std::valarray<bool> operator||(const std::valarray<T>& lhs,

                               const typename std::valarray<T>::value_type & val);
(3)

应用二元运算符到二个 valarray 的对应元素,或一个 valarray 和一个值。

1) 运算符作用于拥有同样大小的 valarray 并返回大小等于参数的 valarray ,将运算应用到二个参数的每个元素。
2,3) 在 valarray 的每个元素和标量间应用运算符。

参数

rhs - 数值数组
lhs - 数值数组
val - 类型 T 的值

返回值

大小等于参数的 valarray 。

注解

若二个参数是不同大小的 valarray 则行为未定义。

函数能以不同于 std::valarray 的返回类型实现。此情况下,替换类型拥有下列属性:

示例

寻找多个二次方程的实根。

#include <cstddef>
#include <valarray>
#include <iostream>
 
int main()
{
    std::valarray<double> a(1, 8);
    std::valarray<double> b{1, 2, 3, 4, 5, 6, 7, 8};
    std::valarray<double> c = -b;
    // LWG3074 前字面量亦必须拥有 T 类型(此情况下为 double )
    std::valarray<double> d = std::sqrt(b * b - 4.0 * a * c);
    std::valarray<double> x1 = (-b - d) / (2.0 * a);
    std::valarray<double> x2 = (-b + d) / (2.0 * a);
    std::cout << "quadratic equation    root 1,  root 2" << "\n";
    for (std::size_t i = 0; i < a.size(); ++i) {
        std::cout << a[i] << "x\u00B2 + " << b[i] << "x + " << c[i] << " = 0   ";
        std::cout << std::fixed << x1[i] << ", " << x2[i] << std::defaultfloat << "\n";
    }
}

输出:

quadratic equation    root 1,  root 2
1x² + 1x + -1 = 0   -1.618034, 0.618034
1x² + 2x + -2 = 0   -2.732051, 0.732051
1x² + 3x + -3 = 0   -3.791288, 0.791288
1x² + 4x + -4 = 0   -4.828427, 0.828427
1x² + 5x + -5 = 0   -5.854102, 0.854102
1x² + 6x + -6 = 0   -6.872983, 0.872983
1x² + 7x + -7 = 0   -7.887482, 0.887482
1x² + 8x + -8 = 0   -8.898979, 0.898979

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

DR 应用于 出版时的行为 正确行为
LWG 3074 C++98 (2-3) 从标量和 valarray 两者推导 T ,禁止混合类型的调用 仅从 valarray 推导 T