std::ranges::transform_view<V,F>::transform_view
来自cppreference.com
                    
                                        
                    < cpp | ranges | transform view
                    
                                                            
                    |   transform_view() requires std::default_initializable<V> &&  std::default_initializable<F> = default;  | 
(1) | (C++20 起) | 
|   constexpr explicit transform_view( V base, F fun );  | 
(2) | (C++20 起) | 
构造 transform_view。
1) 默认构造函数。值初始化底层视图与变换函数。
2) 从 
base 移动构造视图并从 fun 移动构造变换函数。参数
| base | - | 视图 | 
| fun | - | 变换函数 | 
示例
演示使用 1 的反正切的级数展开的 π 近似:
 atan(1) = π/4 ~ 1 - 1/3 + 1/5 - 1/7 + 1/9 - 1/11 + ...
运行此代码
#include <iomanip> #include <iostream> #include <numbers> #include <numeric> #include <ranges> int main() { std::cout << std::setprecision(15) << std::fixed; auto atan1term = std::ranges::views::transform( [](int n) { return ((n % 2) ? -1 : 1) * 1.0 / (2 * n + 1); } ); for (const int iterations : {1, 2, 3, 4, 5, 10, 100, 1000, 1'000'000}) { auto seq = std::ranges::views::iota(0, iterations) | atan1term; const double accum = std::accumulate(seq.begin(), seq.end(), 0.0); std::cout << "π ~ " << 4 * accum << "(迭代 " << iterations << " 次)\n"; } std::cout << "π ~ " << std::numbers::pi << "(std::numbers::pi)\n"; }
可能的输出:
π ~ 4.000000000000000(迭代 1 次) π ~ 2.666666666666667(迭代 2 次) π ~ 3.466666666666667(迭代 3 次) π ~ 2.895238095238096(迭代 4 次) π ~ 3.339682539682540(迭代 5 次) π ~ 3.041839618929403(迭代 10 次) π ~ 3.131592903558554(迭代 100 次) π ~ 3.140592653839794(迭代 1000 次) π ~ 3.141591653589774(迭代 1000000 次) π ~ 3.141592653589793(std::numbers::pi)
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
| 缺陷报告 | 应用于 | 出版时的行为 | 正确行为 | 
|---|---|---|---|
|  LWG 3714 (P2711R1)  | 
C++20 | 多参数构造函数不是显式的 | 改成显式的 | 
| P2325R3 | C++20 |  如果 F 不 default_initializable ,那么默认构造函数构造不含 F 的 transform_view
 | 
 transform_view 也不default_initializable
 |