std::valarray<T>:: apply
From cppreference.net
|
valarray
<
T
>
apply
(
T func
(
T
)
)
const
;
|
||
|
valarray
<
T
>
apply
(
T func
(
const
T
&
)
)
const
;
|
||
返回一个大小相同的新 valarray,其值通过将函数
func
应用于元素先前的值获得。
目录 |
参数
| func | - | 应用于值的函数 |
返回值
通过应用函数
func
获得值的结果 valarray。
注释
该函数可以实现为返回类型不同于 std::valarray 的情况。此时,替换类型需具备以下特性:
-
- 提供了 const 成员函数的所有 std::valarray 。
- 可以从替换类型构造 std::valarray 、 std::slice_array 、 std::gslice_array 、 std::mask_array 和 std::indirect_array 。
- 对于每个接受 const std:: valarray < T > & 的函数(除 begin() 和 end() 外 (C++11 起) ),应添加接受替换类型的相同函数;
- 对于每个接受两个 const std:: valarray < T > & 参数的函数,应添加接受 const std:: valarray < T > & 与替换类型所有组合的相同函数。
- 返回类型的模板嵌套层级不会超过最深嵌套参数类型的两个层级。
可能的实现
以下简单实现可通过表达式模板替换以获得更高效率。
template<class T> valarray<T> valarray<T>::apply(T func(T)) const { valarray<T> other = *this; for (T& i : other) i = func(i); return other; } template<class T> valarray<T> valarray<T>::apply(T func(const T&)) const { valarray<T> other = *this; for (T& i : other) i = func(i); return other; } |
示例
计算并打印前10个阶乘。
运行此代码
#include <cmath> #include <iostream> #include <valarray> int main() { std::valarray<int> v = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; v = v.apply([](int n) -> int { return std::round(std::tgamma(n + 1)); }); for (auto n : v) std::cout << n << ' '; std::cout << '\n'; }
输出:
1 2 6 24 120 720 5040 40320 362880 3628800
参见
|
对
范围
内的元素应用一元
函数对象
(函数模板) |
|
|
(C++20)
|
对
范围
内的元素应用一元
函数对象
(算法函数对象) |