std::valarray<T>::operator+,-,~,!
来自 cppreference.com
valarray<T> operator+() const; |
(1) | |
valarray<T> operator-() const; |
(2) | |
valarray<T> operator~() const; |
(3) | |
valarray<bool> operator!() const; |
(4) | |
将一元运算符应用于数值数组中的每个元素。
内容 |
[编辑] 参数
(无)
[编辑] 返回值
一个数值数组,包含通过将相应的运算符应用于*this中的值获得的值。
[编辑] 异常
可能抛出实现定义的异常。
[编辑] 注释
如果满足以下要求,则可以实例化每个运算符
- 可以将指定的运算符应用于类型
T
。 - 结果值可以明确地转换为
T
(1-3) 或 bool (4)。
- 可以将指定的运算符应用于类型
该函数可以使用与 std::valarray 不同的返回类型来实现。在这种情况下,替换类型具有以下属性
- 提供 std::valarray 的所有 const 成员函数。
- std::valarray、std::slice_array、std::gslice_array、std::mask_array 和 std::indirect_array 可以从替换类型构造。
- 对于每个使用 const std::valarray<T>& except begin() and end()(自 C++11 起) 的函数,应添加使用替换类型的相同函数;
- 对于每个使用两个 const std::valarray<T>& 参数的函数,应添加使用 const std::valarray<T>& 和替换类型的所有组合的相同函数。
- 返回类型不会在最深嵌套的参数类型之上增加超过两个级别的模板嵌套。
[编辑] 示例
运行此代码
#include <iostream> #include <string_view> #include <valarray> template<typename T> void print(std::string_view const note, std::valarray<T> const vala, // by-value, see Notes above std::string_view const term = "\n") { std::cout << note << std::boolalpha << std::showpos; for (T const element : vala) std::cout << '\t' << element; std::cout << term; } int main() { std::valarray<int> x{1, 2, 3, 4}; print<int>("x: ", x); print<int>("+x: ", +x); print<int>("+ + x: ", + + x); print<int>("-x: ", -x); print<int>("- - x: ", - - x, "\n\n"); std::valarray<short> y{0, 1, -1, 0x7fff}; print<short>("y: ", y); print<short>("~y: ", ~y); print<short>("~~y: ", ~~y, "\n\n"); std::valarray<bool> z{true, false}; print<bool>("z: ", z); print<bool>("!z: ", !z); print<bool>("!!z: ", !!z); }
可能的输出
x: +1 +2 +3 +4 +x: +1 +2 +3 +4 + + x: +1 +2 +3 +4 -x: -1 -2 -3 -4 - - x: +1 +2 +3 +4 y: +0 +1 -1 +32767 ~y: -1 -2 +0 -32768 ~~y: +0 +1 -1 +32767 z: true false !z: false true !!z: true false
[编辑] 另请参见
将复合赋值运算符应用于 valarray 的每个元素 (公共成员函数) | |
将二元运算符应用于两个 valarrays 的每个元素,或一个 valarray 和一个值 (函数模板) |