企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
*  代表一串元素, 或者一串元素中的一段 * 类似 begin/end 对 好处: * 简化语法和方便使用 ~~~cpp vector<int> data{11, 22, 33}; sort(begin(data), end(data)); sort(data); // 使用 Ranges ~~~ * 防止 begin/end 不配对 * 使变换/过滤等串联操作成为可能 相关功能 * 视图(View): 延迟计算, 不持有, 不改写 * Actions: 即时处理(eagerly evaluated), 改写 * Algorithms: 所有接受 begin/end 对的算法都可用 * Views 和 actions 使用管道符`|`串联 ### 例子 * 串联视图 ~~~cpp vector<int> data {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; auto result = data | views::remove_if([](int i) { return i % 2 == 1;}) | views::transform([](int i) { return to_string(i);}); // result = {"2", "4", "6", "8", "10" }; // 注意 以上操作被延迟, 当你遍历result的时候才触发 ~~~ * 串联actions ~~~cpp vector<int> data{4, 3, 4, 1, 8, 0, 8}; vector<int> result = data | actions::sort | actions::unique; ~~~ * 排序然后去重 * 操作会原地对`data`进行更改, 然后返回 * 过滤和变换 ~~~cpp int total = accumulate ( view::ints(1) | view::transform([](int i) {return i * i;}) | view::take(10), 0); ~~~ * `view::ints(1)` 产生一个无限的整型数列 * 平方 * 取前10个元素, 然后累加(accumulate) 所有的计算延迟到`accumulate`累加遍历的时候发生